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

相关推荐
什么都不会的Tristan12 分钟前
MySQL篇
数据库·mysql
卌卄1 小时前
【Linux】MySQL安装配置
linux·运维·mysql
Arbori_262152 小时前
clickhouse 实现mysql GROUP_CONCAT() 函数
数据库·mysql·clickhouse
存在的五月雨3 小时前
Mysql 函数
数据库·mysql
左灯右行的爱情3 小时前
导出重复问题记录-bugs专辑
数据库·mysql
wzy06233 小时前
MySQL UDF 一例
mysql·des/ecb/
仍然.4 小时前
MySQL--库的操作、数据类型、表的操作
数据库·mysql
敲敲千反田5 小时前
MySQL复习
数据库·mysql
JSU_曾是此间年少5 小时前
ubuntu安装2026最新版Mysql(截止到1月底)
数据库·mysql
weixin_462446235 小时前
Hive Metastore 使用 MySQL 8(CJ 驱动)完整配置实战(含完整 Shell 脚本)
hive·hadoop·mysql