join,left join,inner join,full join的区别?

left join(左联接) 返回包括左表中的所有记录和右表中联结字段相等的记录
right join(右联接) 返回包括右表中的所有记录和左表中联结字段相等的记录
inner join(等值连接) 只返回两个表中联结字段相等的行,等于join
full join,在两张表进行连接查询时,返回左表和右表中所有没有匹配的行;即查询结果是left join和right join的并集

A记录如下:
aID     aNum
1     a20050111
2     a20050112
3     a20050113
4     a20050114
5     a20050115

B记录如下:
bID     bName
1     2006032401
2     2006032402
3     2006032403
4     2006032404
8     2006032408

--------------------------------------------
1.left join
sql语句如下
select * from A
left join B 
on A.aID = B.bID

结果如下:
aID     aNum     bID     bName
1     a20050111    1     2006032401
2     a20050112    2     2006032402
3     a20050113    3     2006032403
4     a20050114    4     2006032404
5     a20050115    NULL     NULL

3.inner join
sql语句如下
select * from A
inner join B 
on A.aID = B.bID

结果如下:
aID     aNum     bID     bName
1     a20050111    1     2006032401
2     a20050112    2     2006032402
3     a20050113    3     2006032403
4     a20050114    4     2006032404

 

4.full join
sql语句如下: 
select * from A
full join B 
on A.aID = B.bID

结果如下:

aID     aNum     bID     bName
1     a20050111    1     2006032401
2     a20050112    2     2006032402
3     a20050113    3     2006032403
4     a20050114    4     2006032404
5     a20050115    NULL     NULL
NULL   NULL            8     2006032408

笛卡尔积和inner join结果相同,但是inner join效率快一点join 默认就是 inner join

转载于:https://www.cnblogs.com/liuqing576598117/p/10608646.html

在SQL中,full joinleft joininner join和right join是用于合并两个或多个表的不同方式。区别如下: 1. Left Join(左连接):左连接返回左边表格的所有行,并且只返回与右边表格匹配的行。也就是说,左边表格的所有行都会显示出来,而右边表格只有与左边表格匹配的行才会显示出来。 2. Right Join(右连接):右连接返回右边表格的所有行,并且只返回与左边表格匹配的行。与左连接相反,右连接会显示右边表格的所有行,而左边表格只有与右边表格匹配的行才会显示出来。 3. Inner Join(内连接):内连接只返回左右表格中在连接列上匹配的行。也就是说,只有在左右表格连接列上的值匹配时,才会返回这些行。内连接会过滤掉左右表格中不匹配的行。 4. Full Join(全连接):全连接返回左右表格的所有行,并将左右表格连接列上匹配的行放在一起。如果左右表格连接列上的值不匹配,那么会在结果中单独显示这些行。 需要注意的是,full join在MySQL中不被支持,可以通过左连接和右连接的结合使用来实现类似的功能。使用union操作符可以将左连接和右连接的结果集合并成一个结果集。 例如,可以使用以下查询语句来实现full join的效果: ```sql SELECT * FROM table1 LEFT JOIN table2 ON table1.column = table2.column UNION SELECT * FROM table1 RIGHT JOIN table2 ON table1.column = table2.column; ``` 总结起来,full join返回左右两个表格的所有行,left join返回左边表格的所有行,inner join只返回在连接列上匹配的行,而right join返回右边表格的所有行。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值