本文摘自PHP中文网,作者黄舟,侵删。
今天撸代码时,遇到SQL问题:(相关mysql视频教程推荐:《mysql教程》)
要将A表查询的ID,匹配B表的ID,并将B表全部内容查询出来:
未优化前:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 | MySQL [xxuer]> SELECT
-> COUNT (*)
-> FROM
-> t_cmdb_app_version
-> WHERE
-> id IN ( SELECT
-> pid
-> FROM
-> t_cmdb_app_relation UNION SELECT
-> rp_id
-> FROM
-> t_cmdb_app_relation);
+
| COUNT (*) |
+
| 266 |
+
1 row in set (0.21 sec)
|
优化后:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 | MySQL [xxuer]> SELECT
-> count (*)
-> FROM
-> t_cmdb_app_version a
-> INNER JOIN
-> ( SELECT
-> pid
-> FROM
-> t_cmdb_app_relation UNION SELECT
-> rp_id
-> FROM
-> t_cmdb_app_relation) b ON a.id = b.pid;
+
| count (*) |
+
| 266 |
+
1 row in set (0.00 sec)
|
查看执行计划对比:
阅读剩余部分
相关阅读 >>
mysql创建外键约束的两种方式
mysql初学者可以告别分组聚合查询的困扰了
mysql8.0.11安装配置方法图文教程 mysql8.0新密码认证方式
关于mysql中的时间进位问题的讲解
必看!php开发者常犯的10个mysql错误
【mysql数据库】第四章解读:schema与数据类型优化(上)
mysql居然还能实现分布式锁的方法
mysql常用命令 详细整理版
mysql中四种隔离级别的介绍
mysql数据库必备之条件查询语句
更多相关阅读请进入《inner》频道 >>
机械工业出版社
本书主要讲述了数据模型、基于对象的数据库和XML、数据存储和查询、事务管理、体系结构等方面的内容。
转载请注明出处:木庄网络博客 » 关于mysql优化之IN换INNER JOIN的实例分享