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

相关推荐
invicinble7 小时前
对于mysql层对sql层面的知识体系的理解和把握
数据库·sql·mysql
Nandeska8 小时前
14、MySQL基于GTID的数据同步
数据库·mysql
kyle-fang8 小时前
阿里云服务器部署MySQL
服务器·mysql·阿里云
我是黄骨鱼8 小时前
【零基础学数据库|第二篇】MySql启动!!!
数据库·mysql
Dxy12393102169 小时前
MySQL删除表语句详解
数据库·mysql
uoKent9 小时前
MySQL常见命令梳理大纲
数据库·mysql
予枫的编程笔记9 小时前
【MySQL筑基篇】从排名统计到非结构化存储:MySQL窗口函数与JSON实战教程
mysql·数据处理·窗口函数·后端开发·json数据类型·数据库进阶·mysql高级特性
YIN_尹10 小时前
【MySQL】数据分析双剑客:聚合函数 与 group by子句的完美搭配
mysql·性能优化·数据分析
Dxy123931021610 小时前
Python判断MySQL表是否存在,不存在则创建
python·mysql·adb
我是黄骨鱼10 小时前
【零基础学数据库|第一篇】绪论
mysql