位置: 编程技术 - 正文

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

  • 企业所得税年报申报时间
  • 车辆购置税的纳税义务发生时间为
  • 税收的经济效应是指税收对纳税人生产
  • 以前年度遗留的个税怎么处理
  • 开票系统怎么切换到数字账户
  • 预缴所得税的计税依据
  • 甲供材和清包工的账务处理
  • 坏账冲回要纳税调减吗
  • 支付结算有哪些工具
  • 募捐建议
  • 委托加工物资加工费怎么结转
  • 银行现金解款单回单怎么填
  • 资本公积转增股本什么意思
  • 开具发票给顾客公司需要交纳什么税?
  • 土地增值税的征税对象,是村集体
  • 公司用的冰箱
  • 失业保险费退还计入什么科目
  • 1697507802
  • 已确定收入后补缴增值税
  • 购买基金会计核算
  • 专项应付款会计科目代码
  • 单位购买短期保本理财产品如何做账?
  • 不超过500万元的固定资产
  • 年度企业所得税申报表在哪里打印
  • 电脑管家免费wifi
  • php排队系统
  • 无线路由器如何桥接wifi信号
  • 在php中,字符串有哪些表示形式
  • 资产负债表存货包括哪些科目
  • PHP:pg_fetch_result()的用法_PostgreSQL函数
  • 盈余公积科目是什么科目
  • php yeid
  • 存货怎么预估
  • 提高支票处理效率的有效方法是
  • 废旧物资处理怎么入账
  • 微信小程序登录后端
  • 已勾选确认的发票怎样撤销勾选
  • 小程序官方组件展示
  • java中的gui是什么
  • 客运公司做账怎么做
  • 申报纳税的税务机关
  • mongodb怎么导入文件
  • 通讯补贴算福利费吗
  • 坏账的计算公式
  • 发票认证后总局没信息
  • SQL Server 2008中SQL查询语句字段值不区分大小写的问题解决
  • 营业总收入同比增长怎么分析
  • 建筑业周转材料
  • 员工的医药费计入什么科目
  • 房地产中介公司排名
  • 社保都有哪几项
  • 现金管理办法的内容包括
  • 小企业营业外收入包括
  • 建筑设计行业收费标准
  • 预付费用款项现金流量怎么算
  • 现值指数与净现值的关系
  • 没有发票就不能保修吗
  • 其他收入属于什么收入
  • sql servers
  • centos7搜索
  • find linux命令详解
  • win7系统怎么备份文件
  • win8不能启动
  • centos什么命令都说找不到
  • fedora23安装
  • linux中make
  • win10电脑提示
  • unity3ds
  • python计算两个数的最大公约数
  • 用jquery制作网页
  • 备份系统三要素
  • javascript编程技术
  • jquery mobile demo
  • unity效率
  • 新疆干部在线网络平台登录
  • 税务局和国税
  • 出口退税应退税额未发生变化 骗税
  • 出口退税是指对出口货物退还其在国内
  • 如何做好税务党建工作
  • 税务总局2016年70号公告
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设