【MySQL8】内外连接的SQL99 和 SQL92的两种写法

我先说个结论

  • MySQL仅支持SQL92语法的内连接,不支持SQL92语法的外连接
  • MySQL支持SQL99语法的内连接和外连接
  • 所以,一了百了,内连接和外连接的写法全写SQL99语法好了
  • 再补一句,SQL99支持满外连接,但是MySQL不支持FULL JOIN(满外连接),但是可以用 LEFT JOIN UNION RIGHT join代替

1.内连接

sql 复制代码
#SQL92语法实现内连接:
SELECT employee_id,department_name
FROM employees e,departments d
WHERE e.`department_id` = d.department_id;   # 需要使用左外连接


#SQL99语法实现内连接:
SELECT last_name,department_name
FROM employees e INNER JOIN departments d
ON e.`department_id` = d.`department_id`;

SELECT last_name,department_name,city
FROM employees e JOIN departments d
ON e.`department_id` = d.`department_id`
JOIN locations l
ON d.`location_id` = l.`location_id`;

2.外连接

sql 复制代码
#SQL92语法实现外连接:使用 +  ----------MySQL不支持SQL92语法中外连接的写法!
#不支持:
SELECT employee_id,department_name
FROM employees e,departments d
WHERE e.`department_id` = d.department_id(+);

#SQL99语法中使用 JOIN ...ON 的方式实现多表的查询。这种方式也能解决外连接的问题。MySQL是支持此种方式的。
#SQL99语法如何实现多表的查询。


#SQL99语法实现外连接:

#练习:查询所有的员工的last_name,department_name信息 
# 左外连接:
SELECT last_name,department_name
FROM employees e LEFT JOIN departments d
ON e.`department_id` = d.`department_id`;

#右外连接:
SELECT last_name,department_name
FROM employees e RIGHT OUTER JOIN departments d
ON e.`department_id` = d.`department_id`;


#满外连接:mysql不支持FULL OUTER JOIN
SELECT last_name,department_name
FROM employees e FULL OUTER JOIN departments d
ON e.`department_id` = d.`department_id`;
相关推荐
宇钶宇夕4 分钟前
SIMATIC S7-1200的以太网通信能力:协议与资源详细解析
运维·服务器·数据库·程序人生·自动化
LuckyLay22 分钟前
1.1.1数据类型与变量——AI教你学Django
数据库·django·sqlite
汤姆大聪明1 小时前
Redis 持久化机制
数据库·redis·缓存
brevity_souls2 小时前
什么是时序数据库?——原理、特点与应用
数据库·时序数据库
SelectDB2 小时前
Apache Doris 实时更新技术揭秘:为何在 OLAP 领域表现卓越?
数据库·数据分析·apache
kk在加油3 小时前
Redis数据安全性分析
数据库·redis·缓存
DolphinDB4 小时前
更高效的因子研究工具:基于 DolphinDB 的因子评价框架详解
数据库
此乃大忽悠4 小时前
身份认证缺陷
java·数据库·webgoat·身份认证缺陷
IT项目管理4 小时前
达梦数据库DMDRS搭建单向dm8-dm8数据同步
数据库
咖丨喱5 小时前
【Action帧简要分析】
服务器·数据库·asp.net