MySQL not in嵌套查询如何更改成外连接方式
发布时间:2022-01-12 13:11:33 所属栏目:MySql教程 来源:互联网
导读:这期内容当中小编将会给大家带来有关MySQL not in嵌套查询如何改写成外连接方式,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。 在MySQL中,not in 嵌套查询会在数据库里面创建一张临时表,导致执行效率很低,可以改
这期内容当中小编将会给大家带来有关MySQL not in嵌套查询如何改写成外连接方式,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。 在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> 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) 上述就是小编为大家分享的MySQL not in嵌套查询如何改写成外连接方式了,如果刚好有类似的疑惑,不妨参照上述分析进行理解。 (编辑:丽水站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |