位置: 编程技术 - 正文

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函数用法)

  • 缴纳上一年所得税附件是哪些科目
  • 自来水安装增值税税率
  • 中国注册税务师报考条件
  • 国债收益率如何定价
  • 做了进项税转出后要结转么
  • 本期缴纳上期应缴税额
  • 其他综合收益不能重分类进损益的有哪些
  • 凭证更正方法有哪些
  • 应收账款计提坏账准备是谨慎性原则吗
  • 补发以前年度工资如何计税
  • 持有至到期投资核算内容
  • 私营独资企业需要做账吗
  • 对公业务指什么
  • 水利基金计提比例
  • 广告支持政策
  • 代缴水电费是什么意思
  • 固定资产的运费和关税计入什么费用
  • 仪器购买税率
  • 财会报告需要哪些证书
  • 合伙企业对外投资
  • bios密码如何设置
  • 自主研发全流程
  • 电脑上加速网页的加速器
  • 法人借给公司钱怎么备注
  • php入门基础教程
  • 怎么解决在澳洲吸烟
  • thinkphp分页传递参数
  • 源码阅读技巧
  • 计提未支付的费用
  • 企业重组的特殊性税务处理 税屋
  • php 函数作为参数
  • 购买土地缴纳契税
  • auto.js 逆向
  • 增值税专用发票丢了怎么补救
  • 递归最小二乘法辨识参数
  • 10年未被强制修复!黑客利用Windows旧漏洞攻击通信公司并分发恶意文件
  • linux执行php脚本
  • day02-HTML02
  • 其他应收款包括应收利息吗
  • 织梦相关文章调用
  • mysql in()
  • 发票行业税目怎么选
  • mysql时间格式转换函数
  • 土地出让合同的法律效力
  • 融资租赁缴纳什么税
  • 化妆品的成本利润率
  • 融资租赁固定资产利息的账务处理实例
  • 超期应收款管控
  • 小规模纳税人附加税减半征收
  • 收到国税退税收怎么做账
  • 一般纳税人购货取得普通发票
  • 资本化利息支出在报表哪里
  • 汇算清缴工资调减怎么做账
  • 消耗性生物资产属于非流动资产吗
  • mysql存文章的字段设置为多大?
  • sqlserver2000数据库连接不上
  • 关于植物的现代诗
  • Win10预览版拆弹
  • win8启动文件夹在哪里
  • Win10 Mobile 10572预览版上手体验视频
  • mac版cad2022使用教程
  • symtray.exe - symtray是什么进程 有何作用
  • win1020h2硬件要求
  • 微软新版windows
  • javascript date函数
  • 用nodejs做的项目
  • linux防火墙开启80端口视频
  • js 仿真
  • nodejs连接mongodb副本集
  • 计算字符串的长度的函数
  • unity3d特效教程
  • js中substr,substring,indexOf,lastIndexOf,split,replace的用法详解
  • python socketcan
  • android怎么运行
  • django for
  • 社保已申报怎么停止缴费
  • 国际货运怎么代理
  • 养老专业在职研究生好吗
  • 放管服中的服的深层含义
  • 云南省税务局召开的会议
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设