位置: 编程技术 - 正文

mysql优化系列 DELETE子查询改写优化(mysql优化技巧实战)

编辑:rootadmin

推荐整理分享mysql优化系列 DELETE子查询改写优化(mysql优化技巧实战),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:mysql优化语句,mysql优化总结,mysql常用优化方案,mysql优化总结,mysql常用优化方案,mysql 优化口诀,mysql 优化口诀,mysql优化十大技巧,内容如对您有帮助,希望把文章链接给更多的朋友!

1、问题描述

朋友遇到一个怪事,一个用子查询的DELETE,执行效率非常低。把DELETE改成SELECT后执行起来却很快,百思不得其解。

下面就是这个用了子查询的DELETE了:

几个表的DDL是这样的:

上面这个SQL的执行耗时是:.秒Query OK, 5 rows affected (. sec)如果我们把DELETE改写成SELECT的话,执行耗时仅是:0秒,来对比看下执行计划:

mysql优化系列 DELETE子查询改写优化(mysql优化技巧实战)

可以看到,trade_info 表从的全表扫描(type=ALL)变成了基于主键的等值查询(type=eq_ref),计划扫描数据量也从万变成了1条,而且还可以避免回表,这2个SQL对比代价相差巨大。

2、优化思路

既然这个SQL把DELETE改成SELECT后执行效率就可以获得很大提升,除此外没特别区别,可能是查询优化器方面有些不足,导致无法直接优化,就得另想办法了。我们的思路是把基于子查询的DELETE简化改写成多表JOIN后DELETE(一般来说,子查询效率比较低的话,可以考虑改写成JOIN),多表DELETE的语法课参考: t1 FROM t1 LEFT JOIN t2 ON t1.id=t2.id WHERE t2.id IS NULL;

参照上面的形式,改写之后的SQL变成了下面这样:

可以看到新的SQL执行效率相对就高很多了,不需要再扫描万条记录,执行耗时只需:0.秒。

Query OK, 5 rows affected (0. sec)

3、其他建议

虽然MySQL 5.6及以上的版本对子查询做了优化,但从本案例的结果来看,在一些情况下还是不如意。因此,如果发现有些子查询SQL效率比较差的话,可以尝试改写成JOIN形式,看看是否有所提升。此外,也要勇于怀疑查询优化器个别情况下存在不足,想办法绕过这些坑。

MySQL中的常用函数 在MySQL中,函数不仅可以出现在select语句及其子句中,而且还可以出现在update、delete语句中。常用的函数有:1.字符串函数;主要用于处理字符串。2.数

MySQL优化案例系列-mysql分页优化 通常,我们会采用ORDERBYLIMITstart,offset的方式来进行分页查询。例如下面这个SQL:SELECT*FROM`t1`WHEREftype=1ORDERBYidDESCLIMIT,;或者像下面这个不带任何条件的

Advanced Pagination for MySQL(mysql高级分页) 在叶子的文章里谈到了使用innerjoin从而减少了对page的扫描也就是减少了所谓的回表例如:SELECT*FROM`t1`INNERJOIN(SELECTidFROM`t1`ORDERBYidDESCLIMIT,)t2USING(id)

标签: mysql优化技巧实战

本文链接地址:https://www.jiuchutong.com/biancheng/348275.html 转载请保留说明!

上一篇:Mysql彻底解决中文乱码问题的方案(Illegal mix of collations for operation)(mysql 1449解决)

下一篇:MySQL中的常用函数(mysql函数用法)

  • 息税前利润变动率
  • 印花税计税依据是什么
  • 发票的收款人复核怎么写
  • 应付账款不付处理分录如何写?
  • 微小企业税率由3%变为1%客户要求降价
  • 个体户到税务局开专票
  • 增值税普通发票怎么开
  • 个人所得税app入职时间不对
  • 外汇网上申报操作流程图
  • 企业合作开发的研发费怎样加计扣除?
  • 公司账上收到职工的生育津贴如何做账?
  • 付款后多久开发发票
  • 小规模纳税人代理销售税率是多少
  • 按键盘不起作用怎么办
  • 别的公司代缴社保合法
  • win11开机后
  • 华为鸿蒙系统的服务
  • 安装费如何做账
  • 食堂充值管理制度
  • 定期存款是否属于受限资金
  • 8款应用
  • 拍卖本人文字作品原稿
  • php教程 ftp 函数
  • au_.exe是什么进程
  • 原材料预付款如何做账
  • wordpress开发app
  • 银行贷款每个月都要还吗?
  • 一个金税盘可以用一个用户名和密码开票吗
  • thinkphp框架入门
  • php百分比
  • cd播放模式
  • 流动比率取值是取期末
  • 打开的ps关不掉
  • 增值税进项税额计算公式
  • 防洪费属于税金及附加吗
  • 员工休产假不发工资违法吗
  • 已核销的坏账又收回会计分录
  • 销货退回与折让的关系
  • 织梦百科
  • 公对公二手车交易税
  • 小规模纳税人开具增值税专用发票
  • 分公司转款总公司总公司怎样会计处理
  • 货款已退回货已收到怎么办
  • 专票不小心印上划痕
  • 税金及附加多计提了怎么办
  • 顾客抽奖奖项名称
  • 固定资产报废电费怎么算
  • 如何抵扣不动产增值税
  • 购电脑怎么入账
  • 进入四大会计师事务所怎么样
  • 非营利医疗机构有哪些
  • 企业如何进行年报
  • sqlserver自定义函数在哪查看
  • 获得sql数据库信息的方法
  • win9什么意思
  • ffplay播放视频命令
  • 不能用鼠标
  • xp系统好奇怪哦
  • auepuf.exe是什么进程
  • Windows系统通过注册表实现打开CMD并定位到指定文件夹
  • windows8自动开机
  • win 7系统无法删除系统文件
  • xp死机不动
  • mac os 如何备份
  • windows恶意软件删除工具怎么安装
  • centos mail命令
  • Linux系统配置IP地址
  • Metaio in Unity3d 教程--- 四:再谈谈图片扫描之tracking配置文件
  • FIF互动帮助手册系列-HTML手册 flash版
  • express常用中间件
  • 批处理修改hosts 加一行
  • 怎么查看u盘有没有传输过数据
  • jQuery Mobile弹出框
  • python中的变量
  • Android开发中的几种管理机制的使用场景是什么
  • jqueryfilter
  • 南京市国家税务局溧水分局
  • 怎么查税务是否备案
  • 上市股票转为非上市
  • 什么是深入调研工作
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设