SQL之join的简单用法

SQL之join的简单用法

SQL语句的JOIN用于把来自两个或多个表的行结合起来

1)INNER JOIN(内连接)

产生的结果是两个表中交集(相同列里面的相同值)的行。它返回两个表中所有匹配的数据。例如:

sql 复制代码
SELECT *   
FROM TableA   
INNER JOIN TableB ON TableA.PK = TableB.PK;

2)LEFT JOIN(左连接)

结果是左表中的所有行都出现在结果中,而右表中则可能出现空值字段。它返回左表中的所有数据,以及与之匹配的右表中的数据(如果存在)。例如:

sql 复制代码
SELECT *   
FROM employee   
LEFT JOIN department ON employee.department_id = department.department_id;

3)RIGHT JOIN(右连接)

结果是右表中的所有行都出现在结果中,而左表中则可能出现空值字段。它返回右表中的所有数据,以及与之匹配的左表中的数据(如果存在)。例如

sql 复制代码
SELECT *   
FROM employee   
RIGHT JOIN department ON employee.department_id = department.department_id;

4)FULL JOIN(全连接)

结果是两个表中的所有行都出现在结果中,如果某个表中没有与之匹配的行,则对应列会出现空值。它返回两个表中的所有数据(如果存在匹配的话)。例如

sql 复制代码
SELECT *   
FROM employee   
FULL JOIN department ON employee.department_id = department.department_id;

5)NATURAL JOIN(自然连接)

它返回两个表中所有名称相同的列,以及与之匹配的其它列。例如

sql 复制代码
SELECT * FROM employee NATURAL JOIN department;

6)CROSS JOIN

也称为叉积,它返回两个表中的所有可能的行组合,不考虑任何条件。结果中的每个行是两个输入表中的行的组合。例如:

sql 复制代码
SELECT * FROM TableA CROSS JOIN TableB;

7)SELF JOIN

它用于在一个表上自我连接。这通常用于在一张表上反映两个关联的列之间的关系。例如:

sql 复制代码
SELECT * FROM TableA AS t1, TableA AS t2 WHERE t1.id <> t2.id;

8)UNION JOIN

sql 复制代码
SELECT * FROM TableA UNION JOIN TableB;
相关推荐
青年夏日科技工作者7 分钟前
从 MySQL 迁移到 TiDB:使用 SQL-Replay 工具进行真实线上流量回放测试 SOP
sql·mysql·tidb
JosieBook8 分钟前
【数据库】时序数据库选型指南:从大数据视角看IoTDB的核心优势
大数据·数据库·时序数据库·iotdb
paid槮9 分钟前
MySql 知识大汇总
数据库·mysql
赵渝强老师12 分钟前
【赵渝强老师】OceanBase租户的资源管理
数据库·mysql·oracle·oceanbase
归云鹤16 分钟前
QT 动态属性和静态属性
开发语言·数据库·qt
麦兜*32 分钟前
【HTTP】防XSS+SQL注入:自定义HttpMessageConverter过滤链深度解决方案
java·网络·spring boot·sql·spring·http·xss
2025年一定要上岸1 小时前
【Django】-1- 开发项目搭建
数据库·django·sqlite
瀚高PG实验室1 小时前
HighgoDB查询慢SQL和阻塞SQL
数据库·sql·瀚高数据库
I'm a winner1 小时前
LaTeX 表格制作全面指南
数据库