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

相关推荐
五阿哥永琪18 小时前
MySQL 中 VARCHAR、TEXT 与 JSON 类型:区别、场景与选型指南
数据库·mysql·json
Rooting++19 小时前
mysql 算一堆经纬度的距离总长
数据库·mysql
y = xⁿ19 小时前
MySQL:count(1)与count(*)有什么区别,深分页问题
android·数据库·mysql
gjc59219 小时前
踩坑案例:容器方式部署的MySQL无法访问?
数据库·mysql
Dream of maid20 小时前
Mysql(8)约束
数据库·mysql
锦轩韶华20 小时前
MySQL 5.1.73(winx64)安装、Navicat 数据库连接测试及简单数据库sql语句操作记录
mysql
晨曦夜月20 小时前
mysql事务的基本操作
数据库·mysql
想唱rap21 小时前
C++智能指针
linux·jvm·数据结构·c++·mysql·ubuntu·bash
wq_21 小时前
Mysql-MVCC
mysql·面试
看我干嘛!1 天前
mysql主从配置一主一从
数据库·mysql