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

相关推荐
moxiaoran575314 小时前
使用ShardingSphere实现MySQL读写分离(一)
数据库·mysql
V1ncent Chen15 小时前
SQL大师之路 11 外连接和自连接
数据库·sql·mysql·数据分析
gaozhiyong081315 小时前
SpringBoot连接多数据源MySQL、SqlServer等(MyBatisPlus测试)
spring boot·mysql·sqlserver
2601_9486061815 小时前
MySQL B+树索引高度计算与性能阈值探讨
数据库·b树·mysql
lierenvip15 小时前
mysql用户名怎么看
数据库·mysql
未来龙皇小蓝16 小时前
【MySQL-索引调优】07:Sql使用索引注意点
数据库·sql·mysql·性能优化
泯仲16 小时前
从零起步学习MySQL 第十六章:MySQL 分库分表的考量策略
开发语言·mysql
成为你的宁宁17 小时前
【Dockerfile 实战:基于 Ubuntu/CentOS 镜像构建 MySQL 8.4自定义镜像】
mysql·ubuntu·centos·dockerfile
ruanyongjing17 小时前
Navicat for MySQL下载安装教程
数据库·mysql
Y0011123617 小时前
Day7-MySQL-约束
数据库·sql·mysql