sql 左连接 ,右连接,内连接和全外连接的4者区别

left join (左连接):返回包括左表中的所有记录和右表中连接字段相等的记录

左连(左表加公共):select*from t1 left join t2 on t1.##=t2.##

right join (右连接):返回包括右表中的所有记录和左表中连接字段相等的记录。

右连(右表加公共):select*from t1 right join t2 on t1.##=t2.##

inner join (等值连接或者叫内连接):只返回两个表中连接字段相等的行

内连接:select*from t1 corss t2 on t1.##=t2.##

full join (全外连接):返回左右表中所有的记录和左右表中连接字段相等的记录。

全外连:select*from t1 full join t2 on t1.##=t2.##

cross join (交叉连接 ):没有 WHERE 子句的交叉联接将产生连接所涉及的表的笛卡尔积。第一个表的行数乘以第二个表的行数等于笛卡尔积结果集的大小。

交叉连:(笛卡尔积):select*from t1 corss join t2 where t1.##=t2.##

举个例子:

 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

右连接:(右边的表不加限制)

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  程序员

交叉连接:(笛卡尔积)

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容