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

相关推荐
r_oo_ki_e_3 小时前
快速复习mysql
数据库·mysql
羊小蜜.4 小时前
Mysql 03: 连接查询全解——内连接、外连接与复合条件查询
数据库·mysql·算法·连接查询
Java水解4 小时前
【MYSQL】MYSQL学习的一大重点:MYSQL数据类型
后端·mysql
polaris06304 小时前
完美解决phpstudy安装后mysql无法启动
数据库·mysql
笑梦无境5 小时前
mysql基础篇四(多年前整理)
数据库·mysql
yy55275 小时前
Mysql 主从复制与读写分离
android·数据库·mysql
zhenxin01226 小时前
万字详解 MySQL MGR 高可用集群搭建
android·mysql·adb
xxjj998a6 小时前
从MySQL迁移到PostgreSQL的完整指南
数据库·mysql·postgresql
Three~stone6 小时前
MySQL Workbench 8.0.45 安装教程[附安装包]
数据库·mysql
炸炸鱼.6 小时前
MySQL 高可用实战(主主复制 + Keepalived+HAProxy)
数据库·mysql·adb