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

相关推荐
ReaF_star14 小时前
【环保】CentOS 7 安装 MySQL 8 实战记录:从安装到排障一次讲清
linux·mysql·centos
qiuyunoqy14 小时前
MySQL - 2
数据库·mysql
y = xⁿ14 小时前
MySQL学习笔记:乐观锁VS悲观锁/八股总结
笔记·学习·mysql
郝开17 小时前
Docker Compose 本地环境搭建:mysql
mysql·docker·容器
笨鸟先飞的橘猫17 小时前
Mysql——MVCC学习
数据库·学习·mysql
zqit rdlo18 小时前
MYSQL 创建索引
数据库·mysql
2601_9498166818 小时前
MySQL 数据库连接池爆满问题排查与解决
android·数据库·mysql
克里斯蒂亚诺更新18 小时前
mysql添加一个用户
数据库·mysql
看海的四叔20 小时前
【SQL】SQL-常见窗口函数有哪些-上篇
数据库·hive·sql·mysql·数据分析·窗口函数
学Linux的语莫20 小时前
langgraph实操
服务器·数据库·mysql