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

相关推荐
高溪流1 小时前
4.mysql表约束 及 mysql库表设计范式
数据库·mysql·约束
GreatSQL社区2 小时前
MySQL/GreatSQL 游标重解析后条件下推core缺陷深度排查
数据库·mysql
Bdygsl2 小时前
MySQL(7)—— 索引
数据库·mysql
闻哥2 小时前
深入理解 InnoDB 的 MVCC:原理、Read View 与可见性判断
java·开发语言·jvm·数据库·b树·mysql·面试
一只会跑会跳会发疯的猴子3 小时前
php操作mysql数据库增删改查
数据库·mysql·php
gaozhiyong08133 小时前
深度架构拆解:Gemini 3.1 Pro的核心技术突破与国内镜像站实测指南
java·开发语言·jvm·mysql
lierenvip3 小时前
mysql的主从配置
android·mysql·adb
野生技术架构师3 小时前
制造业数据库选型实战:为什么我们从 MySQL 迁移到 TiDB
数据库·mysql·tidb
Java面试题总结4 小时前
MySQL高级SQL秘籍:性能飞升之路
sql·mysql·adb
qq5680180764 小时前
mysql数据被误删的恢复方案
数据库·mysql