位置: 编程技术 - 正文

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子查询嵌套查询)

  • 增值税留存比例50
  • 代销和委托代销区别
  • 金税四期已经开始了吗
  • 个人独资企业是有限责任还是无限责任
  • 交强险怎么查
  • 适用5%征收率的范围
  • 进项税额在贷方怎么登明细账
  • 预估收入增值税申报
  • 预缴的税款
  • 可供出售金融资产会计处理
  • 公司取现备用金违法吗
  • 代扣代缴手续费返还需要缴纳增值税吗
  • 一般纳税人采购收到普通发票
  • 销售回扣分录
  • 业务有提成个税怎么扣
  • 老板给的钱计入什么科目
  • 进项转出滞纳金规定
  • 没有费用报销单发票可以直接报销吗
  • 孵化器虚拟地址多少钱一个啊
  • 专用发票和普通发票的区别在哪里
  • 费用计入资产
  • 维修材料费主要包括
  • 支付宝手续费怎么关闭
  • 软件行业的收入怎么样
  • 广告费和业务宣传费税前扣除基数
  • 房地产开发企业资质证书
  • 招待费的住宿费可以抵扣吗
  • mac电脑遇到问题而重新启动
  • php如何编程
  • 计入固定资产成本的费用
  • 质量扣款入什么科目
  • win10文件夹状态已共享怎样取消
  • 过来人告诉你:女人最珍贵的三种东西,舍得给你说明爱你
  • php wechat
  • logread命令
  • calc下载
  • 银行存款利息应记什么科目
  • 利息收入属于什么要素
  • 两个公司可以是法人吗
  • 增值税一般纳税人
  • 银行询证函快递费计入什么科目
  • 企业的净资产包括固定资产吗
  • 出库单可以自制吗
  • 会计凭证大小写不一致
  • 投资性房地产如何折旧
  • sql2008自动启动服务
  • 乡村道路属于城市道路吗
  • 个人出租商铺如何报税申报,需要什么资料
  • 合伙企业可以退出吗
  • 暂估入库的商品能出库吗
  • 已认证抵扣的发票如何红字信息表
  • 进项税留底怎么处理
  • 结转未交增值税为什么是零
  • 交通运输业营改增
  • 公司定额征收需要什么
  • 存货设置的顺序和内容
  • 删除用户mysql
  • mysql无法配置
  • mysql触发器语句
  • windows主进程rundll32总是用麦克风
  • 如何显示文件后缀win10
  • 王者自动更新怎么关
  • centos 做bond
  • linux如何进行命令操作
  • win10输入法设置快捷键
  • 上传图片 js
  • 初步使用筷子而动作不规范的幼儿保育员应该
  • unityai寻路
  • 安卓编程视频教程
  • 安卓自定义app
  • 置顶聊天折叠怎么关闭
  • python3.9快捷键
  • python smtp ssl
  • python dask
  • 电子发票查询官网入口
  • 陕西电子税务局官网登录入口网址
  • 陕西新版电子税务局怎么使用
  • 改税务报表会有限风险吗
  • 关税由谁来承担
  • 公寓限购是好事吗
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设