数据库左连接、右连接、内连接、全连接区别
基本定义: 
  left join (左连接):返回包括左表中的所有记录和右表中连接字段相等的记录。
  right join (右连接):返回包括右表中的所有记录和左表中连接字段相等的记录。
  inner join (等值连接或者叫内连接):只返回两个表中连接字段相等的⾏。
  full join (全外连接):返回左右表中所有的记录和左右表中连接字段相等的记录。
1、内联接(典型的联接运算,使⽤像 =  或 <> 之类的⽐较运算符)。包括相等联接和⾃然联接。
  内联接使⽤⽐较运算符根据每个表共有的列的值匹配两个表中的⾏。例如,检索 students和courses表中学⽣标识号相同的所有⾏。2、外联接。外联接可以是左向外联接、右向外联接或完整外部联接。
  在 FROM⼦句中指定外联接时,可以由下列⼏组关键字中的⼀组指定:
  1)LEFT  JOIN或LEFT OUTER JOIN
  左向外联接的结果集包括  LEFT OUTER⼦句中指定的左表的所有⾏,⽽不仅仅是联接列所匹配的⾏。如果左表的某⾏在右表中没有匹配⾏,则在相关联的结果集⾏中右表的所有选择列表列均为空值。
  2)RIGHT  JOIN 或 RIGHT  OUTER  JOIN
  右向外联接是左向外联接的反向联接。将返回右表的所有⾏。如果右表的某⾏在左表中没有匹配⾏,则将为左表返回空值。
  3)FULL  JOIN 或 FULL OUTER JOIN
  完整外部联接返回左表和右表中的所有⾏。当某⾏在另⼀个表中没有匹配⾏时,则另⼀个表的选择列表列包含空值。如果表之间有匹配⾏,则整个结果集⾏包含基表的数据值。
3、交叉联接
  交叉联接返回左表中的所有⾏,左表中的每⼀⾏与右表中的所有⾏组合。交叉联接也称作笛卡尔积。
  FROM ⼦句中的表或视图可通过内联接或完整外部联接按任意顺序指定;但是,⽤左或右向外联接指定表或视图时,表或视图的顺序很重要。有关使⽤左或右向外联接排列表的更多信息,请参见使⽤外联接。
⽰例:
 A表         
  id  name 
  1  ⼩王
  2  ⼩李
  3  ⼩刘
  B表
  id  A_id  job
  1  2    ⽼师
  2  4    程序员
内连接:(只有2张表匹配的⾏才能显⽰)
select a.name,b.job from A a  inner join B b on a.id=b.A_id
  只能得到⼀条记录
  ⼩李  ⽼师
左连接:(左边的表不加限制)
select a.name,b.job from A a  left join B b on a.id=b.A_id
  三条记录
  ⼩王  null
  ⼩李  ⽼师
  ⼩刘  null
右连接:(右边的表不加限制)
connect和join的区别select a.name,b.job from A a  right join B b on a.id=b.A_id
  两条记录
  ⼩李  ⽼师
  null  程序员
全外连接:(左右2张表都不加限制)
select a.name,b.job from A a  full join B b on a.id=b.A_id
  四条数据
  ⼩王  null
  ⼩李  ⽼师
  ⼩刘  null
  null  程序员
注:在sql中l外连接包括左连接(left join )和右连接(right join),全外连接(full join),等值连接(inner join)⼜叫内连接。

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。