位置: 编程技术 - 正文

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

  • 小规模纳税人印花税怎样计算
  • 印花税权利许可证照免税吗
  • 社保工伤保险可以交两家公司吗
  • 个人与公司交的税怎么算
  • 电子发票冲红还是作废
  • 外商投资企业清算报告
  • 预售款计入收入吗
  • 抵货款回来的产品叫什么
  • 自己生产的产品用于职工福利
  • 房屋维修基金怎么入帐
  • 交通违章罚款有优惠吗
  • 企业所得税一般是几个点
  • 自收自支事业单位
  • 土地增值税清算报告
  • 现金分红和红利再投是什么意思
  • 税基式减免的内容有哪些?
  • 建筑中小企业
  • 雇主责任险发票可以用复印件吗
  • 上月留底的进项税额本月转出做什么分录
  • 销售退回如何做账
  • 递延所得税资产和递延所得税负债
  • 企业转产是什么意思
  • 员工因违反公司规章制度被辞退有补偿吗
  • 开源鸿蒙适配
  • 结转损益和结转成本
  • linux中链接
  • 电脑dwm.exe是什么
  • framework3.5怎么打开
  • 无偿占用资金企业有哪些
  • 2020年农业病虫害
  • thinkphp框架作用
  • yolov5 anchors 中 K-means聚类
  • ai安装教程2020
  • 计算工业总产值公式
  • 企业所得税核算分录
  • 手工明细账簿怎么登账
  • 外币财务报表的未分配利润
  • 销售不动产预征率是多少
  • python字典添加数据
  • 帝国cms调用api接口
  • 将织梦dedecms转换到wordpress
  • 出租营改增之前取得的有形动产
  • 支付员工的餐费怎么入账
  • 命令行启动服务service
  • 劳务外包会计分录最新
  • 2021年废铁回收
  • 企业所得税季度申报表营业收入怎么填写
  • 科目余额表如何看
  • 债券票面利率与期限成正比
  • 出口退税进项税都抵扣了怎么办
  • 一次性工伤医疗补助金怎么领取
  • 递延所得税资产是什么意思
  • 工程施工人工费,材料费,机械费占多少比例
  • 公转私怎么操作
  • 企业转让固定资产发生的费用
  • 复制糸统
  • win8破解密码开机密码
  • win10edge浏览器下载被阻止
  • service.exe是什么
  • 文件选项夹在哪里
  • win7系统无法修复怎么办
  • printnow.exe - printnow是什么进程 有什么作用
  • win8的计算机在哪里
  • 常用的linux系统版本有哪些
  • 如何汉化游戏
  • linux系列
  • 物联网版块股票
  • bootstrap怎么用
  • jQuery实现非常实用漂亮的select下拉菜单选择效果
  • android打包原理
  • 怎样从零开始
  • uinty实现玩家跟随鼠标位置平滑旋转角度
  • python web开发环境搭建
  • pygame csdn
  • 请问木瓜
  • python 网络编程总结
  • android实时获取微信聊天信息
  • 南京国民政府统治和开辟革命新道路
  • 高新企业人才落户北京
  • 购销合同印花税最新政策2023
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设