位置: 编程技术 - 正文

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

  • 外商投资企业要实缴资本么
  • 印花税的缴纳方式有哪三种
  • 车船使用税怎么网上缴费
  • 税差理论名词解释
  • 工商股权转让费用怎么算
  • 增值税减免税申报明细表免税代码和名称
  • 一次性分红到期还本的会计分录
  • 管道安装固定方式
  • 汽车牌照费用标准
  • 股东个人固定资产怎么查
  • 合并报表负商誉为什么计留存收益
  • 代购货物的缴税情况
  • 企业资产损失所得税税前扣除办法
  • 国有企业驻外人员待遇
  • 门诊药房主要业务
  • 股权资本成本包括什么
  • 支付给员工的讲课费税前列支怎么做?
  • 无息贴息贷款合同印花税
  • 劳务派遣用工的岗位只能在哪些工作岗位上实施
  • 预交税费怎么做分录
  • 房地产企业的收入信息披露范围进一步扩大
  • 商业汇票的样本
  • 酒店筹建是什么意思
  • 企业所得税税前扣除政策
  • 单边征收
  • 2018年终奖个人所得税计算器公式
  • 货代企业所得税优惠政策
  • 个体工商户开服务类型发票怎么开的
  • 园林工程的范围包括哪些?
  • 购买材料再进在建工程的账务处理
  • 增资后工商怎么变更
  • 与权益法核算相关的累计净损益
  • 税控专用设备全额抵扣
  • 印花税的缴纳方式包括
  • 房地产企业售房印花税
  • 路由器间歇性断网怎么解决
  • 技术入股分红怎么计算
  • 证券权益包括哪些内容
  • 如何把文件夹加密码锁手机
  • 无形资产的摊销方法
  • 老电脑更新系统会怎么样
  • 修建污水处理厂施工方案包括哪些内容
  • 股东分红个人所得税怎么算
  • 合伙搞养殖
  • 转让存货属于什么收入
  • Windows下php+mysql5.7配置教程
  • 关停所有swap分区的命令
  • 工业企业计入制造费用的工资还需要交工会经费吗
  • php curl_setopt
  • 前端网页设计的三大技术
  • 加计扣除农产品进项税额是什么意思
  • 企业对外担保代偿能否税前扣除 税务局
  • 微众银行贷款到期晚2天还
  • 结转结余的概念
  • 银行账户收费开什么发票
  • sql server安装出现值不能为null
  • 坏账准备贷方余额期末如何处理
  • 小规模纳税人减按1%怎么计算
  • 未收到货款发票是什么意思
  • 转让股权取得的收入是营业收入吗
  • 技术合同免税备案税务局
  • 存货报废会计账务处理
  • MYSQL数据库应用
  • vista安装图解
  • win8.1网络不可用怎么办
  • ConquerCam.exe进程的详细介绍 ConquerCam进程信息介绍
  • win10太麻烦了
  • win8系统找不到无线网络
  • win7系统桌面图标设置
  • c#7.0新语法
  • js四舍五入两位小数
  • 示例代码
  • 基于JAVASCRIPT实现的可视化工具是
  • python 如何访问数据库
  • 临沂国税地税局领导班子
  • 财政部监制的发票
  • 进出口货物的报关时限
  • 以房产作价投资增值税怎么算
  • 独生子女补贴和退休金一起发吗
  • 香港pcc价格
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设