内连接和外连接区别

在之前,我对MSSQL中的内连接和外连接所得出的数据集不是很清楚。这几天重新温习了一下SQL的书本,现在的思路应该是很清楚了,现在把自己的理解发出来给大家温习下。希望和我一样对SQL的连接语句不太理解的朋友能够有所帮助。(发这么菜的教程,各位大大们别笑话偶了,呵:D ) 有两个表A和表B。 表A结构如下: Aid:int;标识种子,主键,自增ID Aname:varchar 数据情况,即用select * from A出来的记录情况如下图1所示: 图1:A表数据 表B结构如下: Bid:int;标识种子,主键,自增ID Bnameid:int 数据情况,即用select * from B出来的记录情况如下图2所示: 图2:B表数据 为了把Bid和Aid加以区分,不让大家有误解,所以把Bid的起始种子设置为100。 有SQL基本知识的人都知道,两个表要做连接,就必须有个连接字段,从上表中的数据可以看出,在A表中的Aid和B表中的Bnameid就是两个连接字段。 下图3说明了连接的所有记录集之间的关系: 图3:连接关系图 现在我们对内连接和外连接一一讲解。 1.内连接:利用内连接可获取两表的公共部分的记录,即图3的记录集C 语句如下:Select * from A JOIN B ON A.Aid=B.Bnameid 运行结果如下图4所示: 图4:内连接数据 其实select * from A,B where A.Aid=B.Bnameid与Select * from A JOIN B ON A.Aid=B.Bnameid的运行结果是一样的。 2.外连接:外连接分为两种,一种是左连接(Left JOIN)和右连接(Right JOIN)    (1)左连接(Left JOIN):即图3公共部分记录集C+表A记录集A1。            语句如下:select * from A Left JOIN B ON A.Aid=B.Bnameid       运行结果如下图5所示: 图5:左连接数据       说明:             在语句中,A在B的左边,并且是Left Join,所以其运算方式为:A左连接B的记录=图3公共部分记录集C+表A记录集A1             在图3中即记录集C中的存在的Aid为:2 3 6 7 8                        图1中即表A所有记录集A中存在的Aid为:1 2 3 4 5 6 7 8 9             表A记录集A1中存在的Aid=(图1中即A表中所有Aid)-(图3中即记录集C中存在的Aid),最终得出为:1 4 5 9             由此得出图5中A左连接B的记录=图3公共部分记录集C+表A记录集A1,             最终得出的结果图5中可以看出Bnameid及Bid非NULL的记录都为图3公共部分记录集C中的记录;Bnameid及Bid为NULL的Aid为1 4 5 9的四笔记录就是表A记录集A1中存在的Aid。    (2)右连接(Right JOIN):即图3公共部分记录集C+表B记录集B1。       语句如下:select * from A Right JOIN B ON A.Aid=B.Bnameid       运行结果如下图6所示: 图6:右连接数据       说明:             在语句中,A在B的左边,并且是Right Join,所以其运算方式为:A右连接B的记录=图3公共部分记录集C+表B记录集B1             在图3中即记录集C中的存在的Aid为:2 3 6 7 8                        图2中即表B所有记录集B中存在的Bnameid为:2 3 6 7 8 11             表B记录集B1中存在的Bnameid=(图2中即B表中所有Bnameid)-(图3中即记录集C中存在的Aid),最终得出为:11             由此得出图6中A右连接B的记录=图3公共部分记录集C+表B记录集B1,             最终得出的结果图6中可以看出Aid及Aname非NULL的记录都为图3公共部分记录集C中的记录;Aid及Aname为NULL的Aid为11的记录就是表B记录集B1中存在的Bnameid。       总结: 通过上面的运算解说,相信很多人已经想到,上面的情况(包括图3的关系图)说明的都只是A在B的左边的情况, 以下语句B在A的右边的又会出现什么情况呢?? select * from B Left JOIN A ON A.Aid=B.Bnameid select * from B Right JOIN A ON A.Aid=B.Bnameid 其实对图3左右翻转一下就可以得出以下结论: select * from B Left JOIN A ON A.Aid=B.Bnameid和select * from A Right JOIN B ON A.Aid=B.Bnameid所得出的记录集是一样的 而 select * from B Right JOIN A ON A.Aid=B.Bnameid和select * from A Left JOIN B ON A.Aid=B.Bnameid所得出的记录集也是一样的。
### SQL内连接外连接区别详解 #### 定义对比 内连接(`INNER JOIN`)返回的是两个表中满足连接条件的记录集合[^1]。这意味着只有当两表中的数据能够匹配上时,这些数据才会被包含在最终结果集中。 相比之下,外连接(`OUTER JOIN`)不仅会返回符合条件的数据行,还会保留那些无法找到对应匹配项的一侧或者两侧的所有原始数据行[^2]。它进一步细分为左外连接 (`LEFT JOIN`)、右外连接 (`RIGHT JOIN`) 外连接 (`FULL OUTER JOIN`)。 #### 数据范围差异 对于 **内连接** 而言,如果某一条记录在任一参与联接的表格里找不到相配对的信息,则该条目不会出现在最后输出的结果集当中[^3]。 而针对 **外连接** 的情况来说: - 左外连接 (`LEFT JOIN`) 将始终显示左侧表内的全部资料,即使右侧没有对应的项目也会如此处理; - 右外连接 (`RIGHT JOIN`) 则正好相反,优先保障右边的内容完整性; - 至于全外连接 (`FULL OUTER JOIN`) 是指无论哪一边都尽可能多地展示所有可用信息——只要存在至少一侧有相应关联即可呈现出来[^4]。 #### 实际应用举例说明 假设我们有两个简单的关系型数据库表 `Employees` (员工) `Departments`(部门),其中前者包含了每位雇员的名字以及他们所属的具体科室编号;后者则列出了各个分组及其描述性的名称。 ##### 使用 INNER JOIN 获取共同部分 ```sql SELECT Employees.Name AS EmployeeName, Departments.DepartmentName FROM Employees INNER JOIN Departments ON Employees.DepartmentID = Departments.ID; ``` 此查询仅提取那些既存在于 `Employees` 表又能在 `Departments` 找到其参照对象的人员名单与其所在单位称号[^5]。 ##### 应用 LEFT JOIN 查看未分配者 ```sql SELECT Employees.Name AS EmployeeName, Departments.DepartmentName FROM Employees LEFT JOIN Departments ON Employees.DepartmentID = Departments.ID; ``` 这段脚本除了给出已知归属关系之外,还将揭示哪些职员尚未指定任何特定的工作小组,即他们的 DepartmentName 值可能为空(NULL)。 同样可以构建 RIGHT JOIN 或 FULL OUTER JOIN 来探索其他角度下的完整视图。 --- ### 总结 综上所述,在实际操作过程中选择合适的连接方式取决于具体的业务需求:如果你只关心双方都有交集的部分就选用 inner join;要是希望得到更广泛覆盖度的数据展现形式的话,则应该考虑 outer joins 类型之一^.
评论 11
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值