内连接、左连接、右连接

1.内连接:利用内连接可获取两表的公共部分的记录,即图3的记录集C 语句如下:Select * from A JOIN B ON A.Aid=B.Bnameid 运行结果如下图4所示:其实select * from A,B where A.Aid=B.Bnameid与Select * from A JOIN B ON A.Aid=B.Bnameid的运行结果是一样的。
 

 
图4:内连接数据

 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。    

交叉连接:两张表联合没有条件情况下,条数 = 图1 * 图2

在数据库操作中,内连接(Inner Join)、左连接(Left Join)和连接(Right Join)都是用来合并两个或更多表数据的SQL操作,它们的主要区别在于返回结果集的方式: 1. **内连接 (Inner Join)**: - 当两个表之间的记录满足某个特定条件时(即连接条件两边都有匹配的数据),这两个表的行才会出现在结果集中。 - 如果有任何一方的记录不符合连接条件,则该记录不会出现在结果中。 - 示例:查询学生和课程表中的信息,只有当学生选了课程时,两者的组合才会出现在结果里。 2. **左连接 (Left Join)**: - 左侧表(也称为主表)的所有记录都会保留在结果集中,即使侧表没有匹配的数据,也会将左侧表的默认值填充(通常是NULL)。 - 如果侧表有匹配,则结果包含两个表的数据;如果没有匹配,侧列将显示NULL值。 - 示例:查找所有学生及其所选课程,包括未选课的学生和他们的课程信息。 3. **连接 (Right Join)**: - 类似于左连接,但这次是侧表的所有记录会保留下来,左侧表没有匹配的数据则显示NULL。 - 结果集中左侧表的记录总是存在,侧表的记录可能存在也可能不存在。 - 示例:查询所有课程及其选课学生,即使有些课程还没有学生选择,也会列出课程信息。 总结来说,内连接只返回共同存在的数据,而左连接连接分别返回左侧或侧表的所有数据,并通过NULL值补充缺失的部分。在实际应用中,选择哪一种取决于你需要得到的结果是否包含完整的左侧或侧表信息。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值