博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
MySQL not in嵌套查询改写成外连接方式
阅读量:2496 次
发布时间:2019-05-11

本文共 2589 字,大约阅读时间需要 8 分钟。

在MySQL中,not in 嵌套查询会在数据库里面创建一张临时表,导致执行效率很低,可以改成外连接的方式处理,效率会好很多。

not in方式

mysql> select * from dept where deptno not in (select deptno from emp);
+--------+------------+---------+
| deptno | dname      | loc     |
+--------+------------+---------+
|     40 | OPERATIONS | BOSTON  |
|     50 | Research   | BeiJing |
+--------+------------+---------+
2 rows in set (0.00 sec)
mysql> explain select * from dept where deptno not in (select deptno from emp);
+----+-------------+-------+------+---------------+------+---------+------+------+-------------+
| id | select_type | table | type | possible_keys | key  | key_len | ref  | rows | Extra       |
+----+-------------+-------+------+---------------+------+---------+------+------+-------------+
|  1 | PRIMARY     | dept  | ALL  | NULL          | NULL | NULL    | NULL |    5 | Using where |
|  2 | SUBQUERY    | emp   | ALL  | NULL          | NULL | NULL    | NULL |   14 | NULL        |
+----+-------------+-------+------+---------------+------+---------+------+------+-------------+
2 rows in set (0.00 sec)

外连接方式

mysql> select * from dept e left join emp d on e.deptno=d.deptno where d.deptno is null;
+--------+------------+---------+-------+-------+------+------+----------+------+------+--------+
| deptno | dname      | loc     | empno | ename | job  | mgr  | hiredate | sal  | com  | deptno |
+--------+------------+---------+-------+-------+------+------+----------+------+------+--------+
|     40 | OPERATIONS | BOSTON  |  NULL | NULL  | NULL | NULL | NULL     | NULL | NULL |   NULL |
|     50 | Research   | BeiJing |  NULL | NULL  | NULL | NULL | NULL     | NULL | NULL |   NULL |
+--------+------------+---------+-------+-------+------+------+----------+------+------+--------+
2 rows in set (0.00 sec)
mysql> explain select * from dept e left join emp d on e.deptno=d.deptno where d.deptno is null;
+----+-------------+-------+------+---------------+------+---------+------+------+----------------------------------------------------+
| id | select_type | table | type | possible_keys | key  | key_len | ref  | rows | Extra                                              |
+----+-------------+-------+------+---------------+------+---------+------+------+----------------------------------------------------+
|  1 | SIMPLE      | e     | ALL  | NULL          | NULL | NULL    | NULL |    5 | NULL                                               |
|  1 | SIMPLE      | d     | ALL  | NULL          | NULL | NULL    | NULL |   14 | Using where; Using join buffer (Block Nested Loop) |
+----+-------------+-------+------+---------------+------+---------+------+------+----------------------------------------------------+
2 rows in set (0.00 sec)

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/26506993/viewspace-2123663/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/26506993/viewspace-2123663/

你可能感兴趣的文章
linux中用户忘记root的密码--ubuntu版本
查看>>
Spring Boot 5:应用程序启动时初始化资源
查看>>
JMter随记
查看>>
MPU6050开发 -- 卡尔曼滤波(转)
查看>>
Redis主从实战
查看>>
plsql if
查看>>
LuoGu P2002 消息扩散
查看>>
linux 下安装JDK
查看>>
简单的ASP.NET无刷新分页
查看>>
宏定义学习
查看>>
omitting directory `folder/'
查看>>
JavaScript面试题
查看>>
TCollector
查看>>
我的博客网站开发6——博文关键字搜索
查看>>
vim7.1在windows下的编码设置[转]
查看>>
同步器之Exchanger
查看>>
IO流
查看>>
专家观点:即使在云中 硬件同样至关重要
查看>>
loadrunner11录制不成功解决方法(收集)
查看>>
jQuery 基础
查看>>