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

相关推荐
野犬寒鸦2 小时前
从零起步学习MySQL || 第九章:从数据页的角度看B+树及MySQL中数据的底层存储原理(结合常见面试题深度解析)
java·服务器·数据库·后端·mysql·oracle·1024程序员节
方二华3 小时前
5 mysql源码中B+树的构建
数据库·mysql·1024程序员节
小彭律师5 小时前
Docker/K8s部署MySQL的创新实践与优化技巧大纲
mysql·docker·kubernetes
csdn_aspnet8 小时前
在 MacOS 中安装 MySQL 8
mysql·macos
不剪发的Tony老师10 小时前
MySQL 9.5创新版发布,有哪些新功能?
数据库·mysql
布朗克16810 小时前
MySQL 及 SQL 注入详细说明
数据库·sql·mysql·1024程序员节
我科绝伦(Huanhuan Zhou)11 小时前
MySQL一键升级脚本(5.7-8.0)
android·mysql·adb
友友马14 小时前
『 数据库 』MySQL复习 - 内置函数详解
数据库·mysql
ANYOLY14 小时前
慢查询优化
mysql