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

相关推荐
talenteddriver7 小时前
mysql: MySQL索引和排序相关名词概念汇总
数据库·mysql
冰冰菜的扣jio11 小时前
MySQL三大重要日志详解
数据库·mysql
哈里谢顿11 小时前
django操作mysql常见错误大全
mysql·django
zwjapple12 小时前
MySQL SQL 面试核心考点与注意事项总结
数据库·sql·mysql
Knight_AL12 小时前
MySQL 分区表应用案例:优化数据管理与性能
数据库·mysql
luoluoal13 小时前
基于python的爬虫的贵州菜价可视化系统(源码+文档)
python·mysql·django·毕业设计·源码
九皇叔叔13 小时前
MySQL 数据库 MVCC 与锁如何联手解决脏读、不可重复读、幻读
数据库·mysql
哈里谢顿13 小时前
mysql索引影响查询速度的示例demo
mysql
苏琢玉14 小时前
一次受限环境下的 MySQL 数据导出与“可交付化”实践
mysql·php
不会kao代码的小王14 小时前
BoostKit 数据库优化原理分析从 MySQL 到 MariaDB 的性能突破
数据库·mysql·mariadb