最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

关于mysql优化之IN换INNERJOIN的实例分享

来源:动视网 责编:小采 时间:2020-11-09 08:53:05
文档

关于mysql优化之IN换INNERJOIN的实例分享

关于mysql优化之IN换INNERJOIN的实例分享:今天撸代码时,遇到SQL问题:(相关mysql视频教程推荐:《mysql教程》)要将A表查询的ID,匹配B表的ID,并将B表全部内容查询出来:未优化前:MySQL [xxuer]> SELECT -> COUNT(*) -> FROM -> t_cmdb_app_version
推荐度:
导读关于mysql优化之IN换INNERJOIN的实例分享:今天撸代码时,遇到SQL问题:(相关mysql视频教程推荐:《mysql教程》)要将A表查询的ID,匹配B表的ID,并将B表全部内容查询出来:未优化前:MySQL [xxuer]> SELECT -> COUNT(*) -> FROM -> t_cmdb_app_version


今天撸代码时,遇到SQL问题:

(相关mysql视频教程推荐:《mysql教程》)

要将A表查询的ID,匹配B表的ID,并将B表全部内容查询出来:

未优化前:

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)

优化后:

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 [xxuer]> explain 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);
+----+--------------------+---------------------+-------+---------------+---------+---------+------+------+--------------------------+
| id | select_type | table | type | possible_keys | key | key_len | ref | rows | Extra |
+----+--------------------+---------------------+-------+---------------+---------+---------+------+------+--------------------------+
| 1 | PRIMARY | t_cmdb_app_version | index | NULL | PRIMARY | 4 | NULL | 659 | Using where; Using index |
| 2 | DEPENDENT SUBQUERY | t_cmdb_app_relation | ALL | NULL | NULL | NULL | NULL | 383 | Using where |
| 3 | DEPENDENT UNION | t_cmdb_app_relation | ALL | NULL | NULL | NULL | NULL | 383 | Using where |
| NULL | UNION RESULT | <union2,3> | ALL | NULL | NULL | NULL | NULL | NULL | Using temporary |
+----+--------------------+---------------------+-------+---------------+---------+---------+------+------+--------------------------+
4 rows in set (0.00 sec)
MySQL [xxuer]> explain 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;
+----+--------------+---------------------+--------+---------------+---------+---------+-------+------+--------------------------+
| id | select_type | table | type | possible_keys | key | key_len | ref | rows | Extra |
+----+--------------+---------------------+--------+---------------+---------+---------+-------+------+--------------------------+
| 1 | PRIMARY | <derived2> | ALL | NULL | NULL | NULL | NULL | 766 | Using where |
| 1 | PRIMARY | a | eq_ref | PRIMARY | PRIMARY | 4 | b.pid | 1 | Using where; Using index |
| 2 | DERIVED | t_cmdb_app_relation | ALL | NULL | NULL | NULL | NULL | 383 | NULL |
| 3 | UNION | t_cmdb_app_relation | ALL | NULL | NULL | NULL | NULL | 383 | NULL |
| NULL | UNION RESULT | <union2,3> | ALL | NULL | NULL | NULL | NULL | NULL | Using temporary |
+----+--------------+---------------------+--------+---------------+---------+---------+-------+------+--------------------------+
5 rows in set (0.00 sec)

文档

关于mysql优化之IN换INNERJOIN的实例分享

关于mysql优化之IN换INNERJOIN的实例分享:今天撸代码时,遇到SQL问题:(相关mysql视频教程推荐:《mysql教程》)要将A表查询的ID,匹配B表的ID,并将B表全部内容查询出来:未优化前:MySQL [xxuer]> SELECT -> COUNT(*) -> FROM -> t_cmdb_app_version
推荐度:
标签: in 示例 mysql
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top