【表A】
Aid    Aname   Acode
1       aa      001
2       bb      002
3       cc      003
4       dd      004
5       ee      005
【表B】
Bid    Bname    Bcode
1       aaa      101
3       bbb      102
5       ccc      103
7       ddd      104
9       eee      105
 
----------------------------------------------------------------------------
left join:左联接
返回包括左表中的所有记录和右表中联结字段相等的记录。
 
例:
SELECT *
FROM A
LEFT JOIN B
ON A.Aid=B.Bid
结果:
Aid    Aname   Acode   Bid   Bname   Bcode
1       aa      001     1     aaa     101
2       bb      002    NULL   NULL    NULL
3       cc      003     3     bbb     102
4       dd      004    NULL   NULL    NULL
5       ee      005     5     ccc     103
 
 
----------------------------------------------------------------------------

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

 
例:
SELECT *
FROM A
Right JOIN B
ON A.Aid=B.Bid
结果:
Aid    Aname   Acode   Bid   Bname   Bcode
1       aa      001     1     aaa     101 
3       cc      003     3     bbb     102
5       ee      005     5     ccc     103
NULL    NULL    NULL    7     ddd     104
NULL    NULL    NULL    9     eee     105
 
 
----------------------------------------------------------------------------

inner join:内联接
只返回两个表中联结字段相等的行。

例:
SELECT *
FROM A
INNER JOIN B       //INNER可以不写
ON A.Aid=B.Bid
结果:
Aid    Aname   Acode   Bid   Bname   Bcode
1       aa      001     1     aaa     101 
3       cc      003     3     bbb     102
5       ee      005     5     ccc     103
 
 
----------------------------------------------------------------------------

full join:全联接
返回两个表中所有字段。

例:
SELECT *
FROM A
FULL JOIN B  
ON A.Aid=B.Bid
结果:
Aid    Aname   Acode   Bid   Bname   Bcode
1       aa      001     1     aaa     101
2       bb      002    NULL   NULL    NULL
3       cc      003     3     bbb     102
4       dd      004    NULL   NULL    NULL
5       ee      005     5     ccc     103
NULL    NULL    NULL    7     ddd     104
NULL    NULL    NULL    9     eee     105

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

cross join:交叉联接
返回两个表的笛卡儿积。

例1:
SELECT *
FROM A
Cross JOIN B  
结果:
Aid    Aname   Acode   Bid   Bname   Bcode
1                       1
2                       1
3                       1
4        (5*5条)       1
5                       1
1                       3
2                       3
……
……
……
例2:
SELECT *
FROM A
Cross JOIN B 
WHERE
A.Aid = B.Bid
结果:
Aid    Aname   Acode   Bid   Bname   Bcode
1       aa      001     1     aaa     101 
3       cc      003     3     bbb     102
5       ee      005     5     ccc     103
 
与inner join 结果一样,实际上是先返回所有结果(25条),再从中查询符合WHERE的结果。
 

SQL Server [join] 整理的更多相关文章

  1. SQL Server Join方式

    原文:SQL Server Join方式 0.参考文献 Microsoft SQL Server企业级平台管理实践 看懂SqlServer查询计划 1.测试数据准备 参考:Sql Server中的表访 ...

  2. SQL Server通过整理索引碎片和重建索引提高速度

    本文章转载:http://database.51cto.com/art/201108/282408.htm SQL Server数据库中,当索引碎片太多时,就会拖慢数据库查询的速度.这时我们可以通过整 ...

  3. sql server 碎片整理——DBCC SHOWCONTIG

    转自: 1.http://blog.sina.com.cn/s/blog_6d2675450101ks6i.html 2.http://www.cnblogs.com/CareySon/archive ...

  4. SQL Server 语句整理

    1. 创建数据库 create database dbName 2. 删除数据库 drop database dbName 3. 备份sql server --- 创建 备份数据的 device US ...

  5. 提升SQL Server速度整理索引碎片

    转载:http://wenku.baidu.com/view/f64c8a707fd5360cba1adbea.html SQL Server2005索引碎片分析和解决方法   毫无疑问,给表添加索引 ...

  6. SQL Server书籍整理

    1.<Microsoft SQL Server企业级平台管理实践>徐海蔚2.<SQL Server 2005 Performance Tuning性能调校>胡百敬3.<M ...

  7. sql server 知识整理 isnull函数()

    exec sp_helptext ProPrecode_matcode_uf exec sp_helptext 存储过程名字 isnull 函数() SQL Serve中的isnull()函数: is ...

  8. sql server join联结

    join学习起来有点乱,现做如下整理: table A id abc 1 a 2 b 3 c 4 d table B id abc 1 e 2 a 3 f 4 c --join或者inner join ...

  9. SQL Server join介绍

    介绍Inner Join(可以省略Inner,平常经常inner,就是inner join), Full Out Join,Cross Join,Left Join, Right Join区别. )) ...

随机推荐

  1. 16_TLB与流水线

    1 前面做的实验起始有缺陷 访问内存之后,后面执行两句代码后:并不能保证刚才访问的代码还在TLB中:有可能被刷新出去了: 实验验证缺陷: 代码 不连续 TLB 被淘汰: 2万次中有1次被淘汰:由于访问 ...

  2. linux部署tomcat项目

    unzip apache-tomcat-7.0.55-windows- x64.zip     解压zip文件 chmod +x startup.sh shutdown.sh catalina.sh ...

  3. Loop Sql

    -- Numeric FOR loop -- set serveroutput on -->> do not use in TOAD -- DECLARE k ; BEGIN .. LOO ...

  4. RedHat版本Linux安装chrome-stable配合chromeDriver进行自动化测试环境准备

    一.Linux机器安装google-chrome-stable 1.设置google-chrome软件源 sudo vim /etc/yum.repos.d/google-chrome.repo [g ...

  5. python_django_views视图模块

    视图(views.py):接收web请求,并响应web请求 在视图响应web请求的过程中,响应文件可能是网页,也可能是json数据 若响应的是网页,我们可分为: 地址重定向的网页请求(子类HttpRe ...

  6. 打造“云边一体化”,时序时空数据库TSDB技术原理深度解密

    本文选自云栖大会下一代云数据库分析专场讲师自修的演讲——<TSDB云边一体化时序时空数据库技术揭秘> 自修 —— 阿里云智能数据库产品事业部高级专家 认识TSDB 第一代时序时空数据处理工 ...

  7. 前端 -- javas-基本语法/引用等

    javas-基本语法/引用等 JavaScript介绍 JavaScript是运行在浏览器端的脚步语言,JavaScript主要解决的是前端与用户交互的问题,包括使用交互与数据交互. JavaScri ...

  8. delphi Sqlite

    Delphi中SQLite如何读写二进制字段(Blob类型) 在Delphi中,有大量的组件可以操作SQLite数据库,如UniDAC就是其中一个比较优秀的,当然还有ASQLite3Component ...

  9. weblux上传图片

    我是接口接收图片然后上传到阿里云上,由于引入的是spring weblux,所以使用方式不同,代码如下 @PostMapping(value = "/upload", consum ...

  10. Go中的switch fallthrough

      Go基础 switch sExpr { case expr1: some instructions case expr2: some other instructions case expr3: ...