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

相关推荐
广师大-Wzx4 小时前
一篇文章看懂MySQL数据库(下)
java·开发语言·数据结构·数据库·windows·python·mysql
爱学习的小邓同学6 小时前
MySQL --- MySQL数据库基础
数据库·mysql
飞yu流星8 小时前
mysql 基础
数据库·mysql·oracle
零陵上将军_xdr8 小时前
MySQL 事务写入流程详解
android·数据库·mysql
乐之者v9 小时前
20多个表,每个都有userId 和其他几个属性,要根据userId把他们全部汇总,如何处理?
java·mysql
我登哥MVP10 小时前
【Spring6笔记】 - 11 - JDBCTemplate
java·数据库·spring boot·mysql·spring
Ahern_10 小时前
PolarDB 8.4.19 单节点安装
mysql·centos
2401_8274999911 小时前
python项目实战11-正则表达式基础
python·mysql·正则表达式
Dream of maid12 小时前
Mysql(6)关联查询
数据库·mysql
源来猿往12 小时前
mysql转postgresql【平移】
数据库·mysql·postgresql