【MySQL】如何编写 LEFT JOIN 减去 INNER JOIN 的 SQL 语句

数据模拟

员工表(employee)

id (主键ID) name (姓名)
1 小明
2 小红
3 小兰
4 小刚
5 小强

员工对应信息表(employee_info)

id (主键ID) employee_id (外键,用户表ID) sex (性别) age (年龄)
1 2 18
2 3 15
3 5 16

目的

查询出员工在信息表没有数据的员工姓名,效果如下

id name
1 小明
4 小刚

SQL 代码

第一种写法(LEFT OUTER JOIN 搭配 IS NULL 的写法)

sql 复制代码
SELECT e.*
FROM employee e
		LEFT OUTER JOIN employee_info ei ON e.id = ei.employee_id
WHERE ei.employee_id IS NULL

第二种写法(NOT EXISTS 写法)

sql 复制代码
SELECT e.*
FROM employee e
WHERE NOT EXISTS (
	SELECT 1
	FROM employee_info ei
	WHERE e.id = ei.employee_id 
)

参考

SQL - 如何编写从 LEFT JOIN 结果中减去 INNER JOIN 结果的 SQL 查询?

相关推荐
秦渝兴11 分钟前
用 Docker Compose 一键部署高可用集群(MySQL + Tomcat + Nginx)
运维·mysql·nginx·docker·容器·tomcat
slyybw13 分钟前
MySQL SQL语句
sql·mysql·oracle
jgbazsh14 分钟前
【MySQL】mysqldump使用方法
数据库·mysql·oracle
吾诺25 分钟前
如何在Linux中找到MySQL的安装目录
linux·运维·mysql
悲伤小伞34 分钟前
10-MySQL_事务管理
linux·数据库·c++·mysql·centos
钰衡大师38 分钟前
MySQL服务器表导入本地开发环境
服务器·mysql
qq_283720051 小时前
MySQL技巧(六):忘记密码的7种自救方案与深度解析
数据库·mysql
冬夜戏雪1 小时前
MVCC、锁
mysql
F1FJJ1 小时前
Shield CLI v0.3.0:插件系统上线,首发 MySQL Web 管理
网络·数据库·网络协议·mysql·容器·golang
Seven971 小时前
MySQL锁机制:从全局锁到行级锁的深度解读
mysql