【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 查询?

相关推荐
二狗mao23 分钟前
整理了索引几道面试热题的简答
mysql
6+h30 分钟前
【MySQL】事务隔离与MVCC详解
数据库·mysql
luom010232 分钟前
【MySQL 的数据目录】
数据库·mysql·adb
深蓝轨迹1 小时前
乐观锁 vs 悲观锁 含面试模板
java·spring boot·笔记·后端·学习·mysql·面试
泯仲4 小时前
从零起步学习MySQL 第十章:深入了解B+树及B+树的性能优势
b树·学习·mysql
hjxu20164 小时前
【 MySQL 速记5】插入
android·数据库·mysql
sea12166 小时前
Flask配置MySQL连接信息的最佳实践
python·mysql·flask
dreamread6 小时前
Linux下MySQL的简单使用
linux·mysql·adb
夕除7 小时前
MySQL--008
数据库·mysql
顶点多余7 小时前
MysqL---表的内外连接 (重点)
数据库·mysql