SQL server 内连接 左连接 右连接 全连接 语句

在SQL Server中,连接(JOIN)操作用于从两个或多个表中检索相关数据。内连接、左连接、右连接和全连接是最常用的几种连接类型。下面详细介绍每种连接的用法和区别:

1. 内连接 (INNER JOIN)

内连接只返回两个表中满足连接条件的匹配行。如果某一行在其中一个表中没有匹配项,则该行不会出现在结果集中。

复制代码

sqlCopy Code

SELECT A.列名, B.列名 FROM 表A A INNER JOIN 表B B ON A.共同列 = B.共同列;

2. 左连接 (LEFT JOIN 或 LEFT OUTER JOIN)

左连接会返回左表中的所有行以及右表中满足连接条件的匹配行。即使右表中没有匹配项,左表的行也会包括在结果集中,未匹配的右表列会显示为NULL。

复制代码

sqlCopy Code

SELECT A.列名, B.列名 FROM 表A A LEFT JOIN 表B B ON A.共同列 = B.共同列;

3. 右连接 (RIGHT JOIN 或 RIGHT OUTER JOIN)

右连接返回右表中的所有行以及左表中满足连接条件的匹配行。即使左表中没有匹配项,右表的行也会包括在结果集中,未匹配的左表列会显示为NULL。

复制代码

sqlCopy Code

SELECT A.列名, B.列名 FROM 表A A RIGHT JOIN 表B B ON A.共同列 = B.共同列;

4. 全连接 (FULL JOIN 或 FULL OUTER JOIN)

全连接返回两个表中的所有行。不论在另一表中是否有匹配项,两表的所有行都会包含在结果集中。未匹配的列会显示为NULL。

复制代码

sqlCopy Code

SELECT A.列名, B.列名 FROM 表A A FULL JOIN 表B B ON A.共同列 = B.共同列;

示例说明

假设有两个表:EmployeesDepartments

Employees:

EmployeeID EmployeeName DepartmentID
1 Alice 10
2 Bob 20
3 Charlie 30

Departments:

DepartmentID DepartmentName
10 HR
20 IT
40 Admin
内连接示例:
复制代码

sqlCopy Code

SELECT Employees.EmployeeName, Departments.DepartmentName FROM Employees INNER JOIN Departments ON Employees.DepartmentID = Departments.DepartmentID;

结果:

EmployeeName DepartmentName
Alice HR
Bob IT
左连接示例:
复制代码

sqlCopy Code

SELECT Employees.EmployeeName, Departments.DepartmentName FROM Employees LEFT JOIN Departments ON Employees.DepartmentID = Departments.DepartmentID;

结果:

EmployeeName DepartmentName
Alice HR
Bob IT
Charlie NULL
右连接示例:
复制代码

sqlCopy Code

SELECT Employees.EmployeeName, Departments.DepartmentName FROM Employees RIGHT JOIN Departments ON Employees.DepartmentID = Departments.DepartmentID;

结果:

EmployeeName DepartmentName
Alice HR
Bob IT
NULL Admin
全连接示例:
复制代码

sqlCopy Code

SELECT Employees.EmployeeName, Departments.DepartmentName FROM Employees FULL JOIN Departments ON Employees.DepartmentID = Departments.DepartmentID;

结果:

EmployeeName DepartmentName
Alice HR
Bob IT
Charlie NULL
NULL Admin

这些示例展示了不同类型连接的行为和返回结果。根据具体需求选择合适的连接类型,可以有效地从数据库中获取所需的信息。

相关推荐
程序员侠客行5 分钟前
Mybatis二级缓存实现详解
java·数据库·后端·架构·mybatis
早点睡觉好了16 分钟前
JAVA中基本类型和包装类型的区别
java·开发语言
Tipriest_17 分钟前
linux中的文本分接流tee命令介绍
linux·服务器·数据库
爱喝水的鱼丶18 分钟前
SAP-ABAP:在SAP世界里与特殊字符“斗智斗勇”:一份来自实战的避坑指南
运维·服务器·数据库·学习·sap·abap·特殊字符
阿拉伯柠檬19 分钟前
MySQL内置函数
linux·数据库·mysql·面试
小Mie不吃饭24 分钟前
2025 Oracle小白零基础到入门的学习路线
数据库·oracle
麒qiqi29 分钟前
SQLite3 数据库
数据库·oracle
码农水水31 分钟前
国家电网Java面试被问:二叉树的前序、中序、后序遍历
java·开发语言·面试
Respect@34 分钟前
qml之TableViewColumn
开发语言·qml
不吃橘子的橘猫41 分钟前
NVIDIA DLI 《Build a Deep Research Agent》学习笔记
开发语言·数据库·笔记·python·学习·算法·ai