字典翻译 问答 其它 leftjoin与rightjoin区别如果紧紧只是说以前的表为主表就用leftjoin,后面的表为主表就用rightjoin的话.那怎么就不把前后两个表的位置换一下?这样不是只要一个左或者右链接就行了?
问题标题:
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   没有这种写法,错误的语句.
点击显示
其它推荐
热门其它推荐
  • 其它