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

相关推荐
神仙别闹9 分钟前
基于 PHP + MySQL 图书库存管理系统
android·mysql·php
Database_Cool_2 小时前
湖仓一体落地实践:阿里云 AnalyticDB MySQL + Hudi/Iceberg 最佳架构方案
数据库·mysql·阿里云
czhc11400756632 小时前
6.9:Mysql
数据库·mysql
三十..12 小时前
MySQL 从入门到高可用架构实战精要
运维·数据库·mysql
你想考研啊13 小时前
mysql数据库导出导入
数据库·mysql·oracle
十年编程老舅14 小时前
Linux DRM:底层逻辑与实践架构
数据库·mysql
AOwhisky16 小时前
MySQL 学习笔记(第六期):MySQL 备份与恢复
运维·数据库·笔记·学习·mysql·云计算
j_xxx404_17 小时前
MySQL表操作硬核解析:从 CREATE TABLE 到磁盘文件、ALTER TABLE 与 DDL 风险
运维·服务器·数据库·c++·mysql·adb·ai
Fanta丶17 小时前
19.Mysql覆盖索引、前缀索引
mysql
梦想的旅途217 小时前
企业微信API实现外部群消息异步推送的技术架构与实践
mysql·架构·企业微信