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

相关推荐
panzer_maus6 小时前
MySQL 索引介绍与索引优化的简单介绍
数据库·mysql
captain3766 小时前
事务___
java·数据库·mysql
爱学习的小邓同学7 小时前
MySQL --- MySQL数据类型
数据库·mysql
一只大袋鼠9 小时前
MyBatis 入门详细实战教程(一):从环境搭建到查询运行
java·开发语言·数据库·mysql·mybatis
java资料站9 小时前
MySQL 8.0.45 完整mysqld_safe启动
数据库·mysql
techdashen10 小时前
一个徽章坏了,顺带扯出了 2.3 万个 feature
数据库·mysql
魂梦翩跹如雨10 小时前
数据库的“契约” —— 约束(Constrains)
java·数据库·mysql
Whitemeen太白12 小时前
查询子级分类、父级分类、叶子节点分类(MySQL / Oracle )
数据库·mysql·oracle
一只游鱼13 小时前
langchain4j+mysql+历史记录
mysql·langchain4j
不爱写程序的东方不败13 小时前
MySQL出现慢查询或者主从延迟的问题,怎么做根因分析?
数据库·mysql