问题标题:
leftjoin与rightjoin区别如果紧紧只是说以前的表为主表就用leftjoin,后面的表为主表就用rightjoin的话.那怎么就不把前后两个表的位置换一下?这样不是只要一个左或者右链接就行了?
问题描述:
leftjoin与rightjoin区别
如果紧紧只是说以前的表为主表就用leftjoin,后面的表为主表就用rightjoin的话.那怎么就不把前后两个表的位置换一下?这样不是只要一个左或者右链接就行了?
阮伯如回答:
AleftjoinB的连接的记录数与A表的记录数同
ArightjoinB的连接的记录数与B表的记录数同
AleftjoinB等价BrightjoinA
tableA:
Field_K,Field_A
1a
3b
4c
tableB:
Field_K,Field_B
1x
2y
4z
selecta.Field_K,a.Field_A,b.Field_K,b.Field_B
fromaleftjoinbona.Field_K=b.Field_K
Field_KField_AField_KField_B
----------------------------------------
1a1x
3bNULLNULL
4c4z
selecta.Field_K,a.Field_A,b.Field_K,b.Field_B
fromarightjoinbona.Field_K=b.Field_K
Field_KField_AField_KField_B
----------------------------------------
1a1x
NULLNULL2y
4c4z--
举个例子:
假设a表和b表的数据是这样的.
ab
idnameidstock
1a115
2b250
3c
select*fromainnerjoinbona. id=b.id
这个语法是连接查询中的内连接,它产生的结果是
两个表相匹配的记录出现在结果列表中.
根据上面的表,出现的结果是这样的
a.idnameb.idstock
1a115
2b250
----------------------------
select*froma,bwherea. id=b.id
这个语法是内连接的另外一种写法,其执行结果与innerjoin一样
--------------------------------
select*fromaleft/rightjoinbona. id=b.id
这个是外连接语法中的左外连接或右外连接
如果是左外连接的话,它将显示a表的所有记录,
selecta.*,b.*fromaleftjoinbona. id=b.id
查询的结果是这样的:
a.idnameb.idstock
1a115
2b250
3cnullnull
--------------------------------------------
如果是右外连接的话,它将显示b表的所有记录,
selecta.*,b.*fromarightjoinbona. id=b.id
查询的结果是这样的:
a.idnameb.idstock
1a115
2b250
--
selecta.*,b.*fromaleftjoinbona.k=b.k
selecta.*,b.*fromaleftouterjoinbona.k=b.k
----------上面两种一样leftjoin是leftouterjoin的简写
selecta.*,b.*fromaleftinnerjoinbona.k=b.k
没有这种写法,错误的语句.
点击显示
其它推荐