位置: 编程技术 - 正文

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

  • 纳税申报的具体要求
  • 非金融企业利息收入计入什么科目
  • 周转材料低值易耗品的会计处理
  • 全面一次性奖金收入扣税标准
  • 存货成本核算方法有哪些
  • 汇兑损益现金流量表列示
  • 综合收益什么时候结算
  • 营业执照经营范围劳务怎么写
  • 资产负债表损益表模板
  • 全额抵扣的发票怎样入账
  • 工会发放节日慰问
  • 软件 企业
  • 税法关于劳务费用的规定
  • 增值税专用发票电子版
  • 一个季度又叫什么
  • 营改增后新纳入增值税征税范围的有
  • 应付账款无法支付所得税处理
  • 公司清算补偿工资标准
  • 申报是不是就是报税
  • 银行承兑汇票开票流程图
  • 分公司注销分配表
  • 公司转让税费如何计算
  • 税务公司属于什么性质
  • 收到财政补贴收入贷记科目是
  • 政府投资农业项目
  • 去年的发票今年怎么做会计分录
  • 如何处理企业所得税纠纷
  • php array_splice
  • kb4507449安装失败
  • 销售农产品的进项税
  • PHP:imagecreatefromgd2part()的用法_GD库图像处理函数
  • 外贸公司出口退税率是多少
  • php 获取当前url
  • java基础面试题选择题
  • 知名个人网站
  • 基于专业性的家校双向互动,需要家长的学校教育参与
  • ps去水印的三种方法
  • 应交税费如何调整
  • 车船税每年都要付吗
  • 单位社保年底清算
  • 资金结存属于什么会计科目
  • 织梦cms为什么不维护了
  • 公司代买社保怎么收费
  • 删除mysql57服务
  • 积分获取和消费的关系
  • 小规模纳税人有个人所得税吗?
  • 酒店客房收入会计分录
  • 技术转让费如何计算
  • 先抵扣后付款怎么做账
  • 预缴的增值税及附加税怎么做账
  • 公司主要产品
  • 卖旧固定资产计入哪个科目
  • 复利现值系数表怎么算
  • 企业应付账款的借方余额反映的是
  • 报销单扣除金额什么意思
  • sql server发布
  • windows7升级到windows8.1
  • wweb32.exe - wweb32是什么进程
  • 注册表怎么优化
  • win10重置此电脑保留我的文件
  • ubuntu好看的字体
  • rsync 教程
  • 微软7月补丁
  • 安卓飞行手游
  • 验证用户输入的密码JavaScript代码加文字
  • opengles入门
  • glGenTextures(GLsizei n, GLuint *textures)函数说明
  • vue左侧菜单栏实现
  • js中的require用法
  • 如何开发一个新的向量库
  • 如何利用python写爬虫
  • python例子大全
  • 国家税务总局公告2022年第9号
  • 高速通行费发票查验
  • 怎么看有没有欠税
  • 税控盘开票怎么添加新商品
  • 劳务派遣服务计税
  • 中华人民共和国刑法
  • csc联合培养博士资助标准
  • 重庆市深化新时代教育评价改革幼儿园
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设