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


本文摘自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》频道 >>


数据库系统概念 第6版
书籍

数据库系统概念 第6版

机械工业出版社

本书主要讲述了数据模型、基于对象的数据库和XML、数据存储和查询、事务管理、体系结构等方面的内容。



打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...