位置: 编程技术 - 正文

mysql in语句子查询效率慢的优化技巧示例(mysql数据查询语句)

编辑:rootadmin

推荐整理分享mysql in语句子查询效率慢的优化技巧示例(mysql数据查询语句),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:mysqljoin查询,mysql查询语句菜鸟教程,mysql in查询语句,mysql查询语句菜鸟教程,mysql数据查询语句,mysql查询语句大全及用法,mysql in语句子查询效率慢的优化技巧示例,mysql用in查询,内容如对您有帮助,希望把文章链接给更多的朋友!

表结构如下,文章只有篇。

其中有个标签的tid是,查询标签tid是的文章列表。

篇文章,用以下的语句查询,奇慢:

其中这条速度很快:

查询结果是五篇文章,id为,,,,

用下面sql来查文章也很快:

解决方法:

其它解决方法:(举例)

为了节省篇幅,省略了输出内容,下同。

rows in set (. sec)

只有行数据返回,却花了秒,而系统中可能同时会有很多这样的查询,系统肯定扛不住。用desc看一下(注:explain也可)

可以看出,在执行此查询时会扫描两百多万行,难道是没有创建索引吗,看一下

从上面的输出可以看出,这两张表在number_id字段上创建了索引的。看看子查询本身有没有问题。

没有问题,只需要扫描几行数据,索引起作用了。

查询出来看看:

直接把子查询得到的数据放到上面的查询中

速度也快,看来MySQL在处理子查询的时候是不够好。我在MySQL 5.1. 和 MySQL 5.5. 都进行了尝试,都有这个问题。

搜索了一下网络,发现很多人都遇到过这个问题:

参考资料1:MySQL优化之使用连接(join)代替子查询

参考资料2:MYSQL子查询和嵌套查询优化实例解析

mysql in语句子查询效率慢的优化技巧示例(mysql数据查询语句)

根据网上这些资料的建议,改用join来试试。修改前:

修改后:

效果不错,查询所用时间几乎为0。看一下MySQL是怎么执行这个查询的

小结:当子查询速度慢时,可用JOIN来改写一下该查询来进行优化。

网上也有文章说,使用JOIN语句的查询不一定总比使用子查询的语句快。

mysql手册也提到过,具体的原文在mysql文档的这个章节:I.3. Restrictions on Subqueries.2.8. Subquery Syntax

摘抄:

1)关于使用IN的子查询:

Subquery optimization for IN is not as effective as for the = operator or for IN(value_list) constructs.

A typical case for poor IN subquery performance is when the subquery returns a small number of rows but the outer query returns a large number of rows to be compared to the subquery result.

The problem is that, for a statement that uses an IN subquery, the optimizer rewrites it as a correlated subquery. Consider the following statement that uses an uncorrelated subquery:

SELECT ... FROM t1 WHERE t1.a IN (SELECT b FROM t2);

The optimizer rewrites the statement to a correlated subquery:

SELECT ... FROM t1 WHERE EXISTS (SELECT 1 FROM t2 WHERE t2.b = t1.a);

If the inner and outer queries return M and N rows, respectively, the execution time becomes on the order of O(M×N), rather than O(M+N) as it would be for an uncorrelated subquery.

An implication is that an IN subquery can be much slower than a query written using an IN(value_list) construct that lists the same values that the subquery would return.

2)关于把子查询转换成join的:

The optimizer is more mature for joins than for subqueries, so in many cases a statement that uses a subquery can be executed more efficiently if you rewrite it as a join.

An exception occurs for the case where an IN subquery can be rewritten as a SELECT DISTINCT join. Example:

SELECT col FROM t1 WHERE id_col IN (SELECT id_col2 FROM t2 WHERE condition);

That statement can be rewritten as follows:

SELECT DISTINCT col FROM t1, t2 WHERE t1.id_col = t2.id_col AND condition;

But in this case, the join requires an extra DISTINCT operation and is not more efficient than the subquery

总结

标签: mysql数据查询语句

本文链接地址:https://www.jiuchutong.com/biancheng/348366.html 转载请保留说明!

上一篇:浅谈mysql的子查询联合与in的效率(mysql的子查询语句)

下一篇:MYSQL子查询和嵌套查询优化实例解析(mysql子查询嵌套查询)

  • 个人所得税既有租房又有房贷
  • 计提所得税分录计提的时候金额比实际缴纳多
  • 出口报关单价比合同价高
  • 预收账款期末余额计算公式
  • 公司章程在工商局
  • 委托收款和托收承付结算方式,都受结算金额起点的限制
  • 私募合伙企业收到投资款后退回,支付利息的会计处理
  • 附加税费申报表出不来数据
  • 开票方没缴税咋办
  • 附加税减免税会计处理怎么做?
  • 打印出来的明细账怎么装订
  • 拿到农产品0税率的发票可以抵扣吗
  • 不动产60%和40%抵扣时间
  • 小规模纳税人免征增值税怎么记账
  • 旧房转让土地增值税核定
  • 营改增一般纳税人申请过渡性财政扶持资金
  • 产品质量认证的基本条件有哪些
  • 企业稀释股份
  • 小微企业附加税怎么算
  • 小规模纳税人适用的增值税征收率
  • 房地产企业已预缴增值税如何抵扣
  • 房地产行业的增值税是多少
  • 购买方现金折扣计入什么科目
  • 安全系统不起作用或未正确安装 cad2016
  • 债券的到期收益率取决于
  • 防暑降温费会计处理
  • 怎么计提企业所得税在哪里知道计提多少
  • 银行与银行之间转账会计摘要
  • php parse_url
  • php面向对象详解
  • linux文件权限控制
  • 应收票据贴现的会计分录
  • 让劳务公司代发工资
  • 让绿萝疯长的妙招
  • 高薪员工辞退补偿金
  • PHP:mcrypt_list_modes()的用法_Mcrypt函数
  • 建设期需要流动资金吗
  • php curl_init
  • php绘制图片
  • 小程序和h5页面的区别
  • 不交社保个税怎么处理
  • 年末本年利润怎么结转
  • 金蝶软件凭证修改怎么做
  • mongodb的基本操作
  • 成本会计的岗位要求
  • 长期待摊费用的摊销方法
  • 个税手续费返还计入哪个科目
  • 无形资产减值准备是什么科目
  • 可供分配的利润包括
  • 水利建设基金应税项是什么
  • 交易性金融资产的账务处理
  • 以前年度损益调整在利润表中怎么填
  • 购入的固定资产,其入账价值包括的内容有
  • 土地承包费和土地租赁费收入记账
  • 三证合一哪三个证
  • 实收资本有关会计科目
  • 小规模收到专票可以当普票用吗
  • 跨年度的项目如何做
  • 会议服务公司名称大全
  • sql分几类
  • sql搜索字段名
  • 快速插入大量数据的asp.net代码(Sqlserver)
  • WIN10系统硬盘设置
  • win2008远程桌面闪退
  • 在linux操作系统中,/etc/rc.d/init.d
  • win8系统蓝屏后无法修复
  • win7电量
  • usb转串口的接线方法
  • win10预览版绿屏重启解决
  • cocos2dx 教程
  • html5的全局属性
  • Unity3D游戏开发毕业论文
  • android edittext被系统键盘遮挡
  • python中pandas.DataFrame的简单操作方法(创建、索引、增添与删除)
  • python如何入门
  • 烟叶的增值税税率9
  • 对外支付税务备案表网上核验
  • 公安驻税务联络办公室
  • 什么是个税扣缴期限
  • 常态化与长效化的区别
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设