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

相关推荐
nbwenren20 小时前
MySQL中日期和时间戳的转换:字符到DATE和TIMESTAMP的相互转换
数据库·mysql
NiKick20 小时前
MySql中的事务、MySql事务详解、MySql隔离级别
数据库·mysql·adb
wellc21 小时前
MySQL Workbench菜单汉化为中文
android·数据库·mysql
ccice011 天前
mysql之如何获知版本
数据库·mysql
九皇叔叔1 天前
MySQL8.0 初始化官网数据
mysql·source·加载数据
ATCH IERV1 天前
MySQL数据库误删恢复_mysql 数据 误删
数据库·mysql·adb
HalvmånEver1 天前
MySQL的数据类型(一)
数据库·mysql
Caspian Wren1 天前
通过Logstash将MySQL数据同步到ES
数据库·mysql·elasticsearch·logstash
历程里程碑1 天前
MySQL事务深度解析:ACID到MVCC实战+万字长文解析
开发语言·数据结构·数据库·c++·sql·mysql·排序算法
橄榄熊1 天前
docker MySQL 密码报错,重新修改保留原样的数据
mysql·docker·容器