首先借用官方的解释下:

inner join(等值连接):只返回两个表中联结字段相等的行;

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

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

比如我们有table1、table2两个表

table1表                                 table2表

---------------                  ----------------------

id     name                     id      score

1      lee                      1       90

2      zhang                    2       100
4      wang                     3       70

  

Sql代码

create table table1(id int,name varchar(10));
create table table2(id int,score int); INSERT INTO table1 (id,NAME) VALUES ('1','lee'),('2','zhang'),('4','wang'); INSERT INTO table2 (id,score) VALUES ('1',90),('2',100),('3',70);

  

  

以下均在查询分析器中执行

一、外连接
1.概念:包括左向外联接、右向外联接或完整外部联接

2.左连接:left join 或 left outer join
(1)左向外联接的结果集包括 LEFT OUTER 子句中指定的左表的所有行,而不仅仅是联接列所匹配的行。如果左表的某行在右表中没有匹配行,则在相关联的结果集行中右表的所有选择列表列均为空值(null)。
(2)sql 语句

select * from table1 left join table2 on table1.id=table2.id;

-------------结果-------------

注释:包含table1的所有子句,根据指定条件返回table2相应的字段,不符合的以null显示

3.右连接:right join 或 right outer join
(1)右向外联接是左向外联接的反向联接。将返回右表的所有行。如果右表的某行在左表中没有匹配行,则将为左表返回空值。
(2)sql 语句

select * from table1 right join table2 on table1.id=table2.id;

-------------结果-------------

注释:包含table2的所有子句,根据指定条件返回table1相应的字段,不符合的以null显示

4.完整外部联接:full join 或 full outer join
(1)完整外部联接返回左表和右表中的所有行。当某行在另一个表中没有匹配行时,则另一个表的选择列表列包含空值。如果表之间有匹配行,则整个结果集行包含基表的数据值。
(2)sql 语句

select * from table1 full join table2 on table1.id=table2.id;

-------------结果-------------
idnameidscore
------------------------------
1lee190
2zhang2100
4wangNULLNULL
NULLNULL370
------------------------------
注释:返回左右连接的和(见上左、右连接)

二、内连接
1.概念:内联接是用比较运算符比较要联接列的值的联接

2.内连接:join 或 inner join

3.sql 语句

select * from table1 join table2 on table1.id=table2.id;

-------------结果-------------

注释:只返回符合条件的table1和table2的列

4.等价(与下列执行效果相同)

A:select a.*,b.* from table1 a,table2 b where a.id=b.id;

B:select * from table1 cross join table2 where table1.id=table2.id; (注:cross join后加条件只能用where,不能用on)

  

三、交叉连接(完全)

1.概念:没有 WHERE 子句的交叉联接将产生联接所涉及的表的笛卡尔积。第一个表的行数乘以第二个表的行数等于笛卡尔积结果集的大小。(table1和table2交叉连接产生3*3=9条记录)

2.交叉连接:cross join (不带条件where...)

3.sql语句

select * from table1 cross join table2;

-------------结果-------------

注释:返回3*3=9条记录,即笛卡尔积

4.等价(与下列执行效果相同)

A:select * from table1,table2;

  

最新文章

  1. 带你玩转Visual Studio
  2. WEB文件上传漏洞介绍解决办法
  3. mysql事务处理用法与实例详解
  4. keepalived程序包
  5. Android应用性能优化之使用SparseArray替代HashMap
  6. 解决Regsvr32: DllRegisterServer entry point was not found
  7. Python的排序
  8. Java 日期 Api
  9. 一、cocos2dx概念简介
  10. 家庭洗车APP --- Androidclient开展 之 网络框架包介绍(一)
  11. cesium编程入门(二)环境搭建
  12. 解决Win10系统下 C# DateTime 出现星期几的问题
  13. Thymeleaf前后端传值 页面取值与js取值
  14. linux配置Anaconda python集成环境
  15. Python入门基础之函数、切片
  16. P1605 迷宫 dfs回溯法
  17. BZOJ4223 : Tourists
  18. cxImage控件使用
  19. linux配置虚拟域名
  20. 【LOJ】#2886. 「APIO2015」巴厘岛的雕塑 Bali Sculptures

热门文章

  1. pat1015. Reversible Primes (20)
  2. js 中 前端过滤数据到后端的方法
  3. 对C++ Local的经典分析(转)
  4. 【Linux相识相知】rpm包管理
  5. [DForm]我也来做自定义Winform之另类标题栏重绘
  6. MySQL中在原表中做数据去重(按日期去重,保留id最小的记录)
  7. 基于CSS3的3D旋转效果
  8. 检测IE浏览器兼容Edge模式及IE11
  9. (转)原生ajax的写法
  10. ant用法