位置: 编程技术 - 正文

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

  • 什么是边际税率高
  • 补报以前年度收入后当年所得税怎么处理
  • 如何开局增值税发票
  • 用友t3软件的系统内没有利润表模块
  • 设备5年直线法计提折旧怎么做
  • 增值税发票注明金额是含税还是不含税
  • 指定扣缴和法定扣缴区别
  • 结转完工产品生产成本会计科目
  • 肉联厂销售模式
  • 租了房子再转租
  • 增值税零税率与免税有何不同
  • 直线法计提折旧的公式预计净残值
  • 一般纳税人取得小规模专用发票可以抵扣吗
  • 跨区域缴纳社保
  • 未及时支付工资时间界限
  • 诉讼财产保全保险费能否主张
  • 客户退回发票会退回吗
  • 企业租车费用怎么处理方法
  • 租金发票会计分录
  • 房产继承税征收标准是多少
  • 建筑业开具发票新规定
  • 房地产企业预缴增值税及附加税
  • 建筑业甲供工程税率
  • 员工入职体检表格模板
  • 专票只能开一万的额度开了三万的发票
  • 个人投资到企业的资金入什么科目
  • 股东分配利润的程序
  • 个人福利需要缴纳个税吗
  • php多维数组转一维数组
  • w11系统黑屏
  • win10电脑记事本打不开显示错误
  • php fopen ftp文件不存在
  • PHP:stream_filter_remove()的用法_Stream函数
  • 工作组只能看到自己
  • 内账怎么处理增值税
  • php如何上传1个g以上的文件
  • 在建工程账务处理管理制度
  • html怎么嵌入js
  • thinkphp dump
  • 跨区域预缴增值税是当月还是次月
  • Ubuntu18.04配置允许远程访问
  • vue中computed作用
  • user-interface console 0 指令无效
  • 完善固定资产管理的方案
  • php上传不了文件
  • 收到房租不开票账务处理
  • 退税没有退的部分怎么做账
  • php_fileinfo不支持
  • 什么发票可以抵扣增值税吗
  • 如何确定固定资产是否已经发生减值
  • 公司支付款项制度
  • 普票和专票的区别对比
  • 研发费用账务处理一定在管理费用吗
  • 应交税费借方是增加还是减少
  • 认缴资金可以增加吗
  • 支付银行贷款利息的会计处理
  • 员工入股会计分录
  • 税控抵税怎么做分录
  • 所有者权益的确认依赖于资产和负债的确认
  • 从会计角度看会计刺客
  • 注册资本和实收资本相等吗
  • 收到银联商务客户短信
  • mysql -u -p -s
  • .NET Framework SQL Server 数据提供程序连接池
  • centos备份文件夹
  • win8.1流畅吗
  • ubuntu系统自带的截图工具
  • windows7怎
  • unity开发用什么电脑比较好
  • js中的三种弹出式消息提醒的命令是什么
  • 使用jquery实现的项目
  • java线程池创建
  • Python编程中的逻辑与控制
  • 浅谈一下新冠的好处
  • 挂车是否需要缴纳车船税
  • 深圳市国税局副局长是谁
  • 个人出租商业用房开票税率
  • 手写发票属于增值税普通发票吗
  • 国税,地税
  • 合伙企业所得税账务处理
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设