转载于:http://www.2cto.com/database/201206/137067.html
 
Sql server left join,right join和inner join的比较
 
今天来研究一下数据库left join 、right join 和 inner join 这三者之间的区别
 
在网上看别人的写过的源代码,绝大多数的应用系统开发,数据库都会有很多的各种各样的join,那些个表table之间join的让人眼花缭乱的,其实一直都是一知半解的状态,
 
因为在公司上班也不用自己去写SQL代码(我这里是指稍微大一点的正规软件公司,很小小公司还是要自己写sql的),因为公司有专门的DBA,通常都是DBA他们写好了,直接给我们存储过程的名字让我们去调用,
 
(下次说存储过程吧,这是个非常重要的东西,几乎都会用到,就像我们做ASP.NET开发一定要知道ADO.NET一样,存储过程这种预编译的SQL脚本对开发是很有好处的,我想在传智播客杨老师的基础视频当中只所以会在页面层代码里面直接写sql查询语句,应该是为了方便教学,节约时间吧)
 
废话不多说,开始学习
 
这里先给出一个官方的解释:
 
left join(左联接) 返回包括左表中的所有记录和右表中联结字段相等的记录
right join(右联接) 返回包括右表中的所有记录和左表中联结字段相等的记录
inner join(等值连接) 只返回两个表中联结字段相等的行
是不是看的有点晕,那下面我们就自己试验吧
 
第一步:建库建表的过程我就省略了,
 
因为昨天的测试有一些简单的代码,就直接在上面稍做修改进行测试,下面插入一点测试数据
 
[sql]  
Insert into Table1 values (1,'姚羽')  
Insert into Table1 values (2,'边兵兵')  
Insert into Table1 values (3,'袁磊')  
Insert into Table1 values (5,'传智博客')  
  
Insert into Table2 values (1,'姚羽')  
Insert into Table2 values (2,'柳春平')  
Insert into Table2 values (3,'张永超')  
Insert into Table2 values (4,'刘华健')  
[sql]  
Insert into Table1 values (1,'姚羽')  
Insert into Table1 values (2,'边兵兵')  
Insert into Table1 values (3,'袁磊')  
Insert into Table1 values (5,'传智博客')  
  
Insert into Table2 values (1,'姚羽')  
Insert into Table2 values (2,'柳春平')  
Insert into Table2 values (3,'张永超')  
Insert into Table2 values (4,'刘华健')  
 
查询出原表的数据如下:

 
我们对比两个table 发现,Table1 中的数据编号分别为1、2、3、5,而Table12中的数据编号分别为1、2、3、4,也就是说两个表中,只有最后一条数据不一样,分别为Table1中id为5的“传智播客”和Table2中id为4的“刘华健”是对应不上的。
好,我们继续...
 
第二步:执行left join 的效果
[sql]  
Select * from Table1 A  
Left join Table2 B  
on A.id = B.id  
[sql]  
Select * from Table1 A  
Left join Table2 B  
on A.id = B.id  

 
(所影响的行数为 4 行)
结果说明:
left join是以A表的记录为基础的,A可以看成左表,B可以看成右表,left join是以左表为准的.
换句话说,左表(A)的记录将会全部表示出来,而右表(B)只会显示符合搜索条件的记录(例子中为: A.id = B.id).
B表记录不足的地方均为NULL.
 
第三步:执行right join 的效果
[sql]  
Select * from Table1 A  
right join Table2 B  
on A.id = B.id  
[sql]  
Select * from Table1 A  
right join Table2 B  
on A.id = B.id  

 
(所影响的行数也为 4 行)
结果说明:
仔细观察一下,就会发现,和left join的结果刚好相反,这次是以右表(B)为基础的,A表不足的地方用NULL填充.
第四步:执行inner join 的效果
[sql]  
Select * from Table1 A  
inner join Table2 B  
on A.id = B.id  
[sql]  
Select * from Table1 A  
inner join Table2 B  
on A.id = B.id  

 
结果说明:
 
很明显,这里只显示出了 A.id = B.id的记录.这说明inner join并不以谁为基础,它只显示符合条件的记录.
好了,到此为止,总算弄清楚这两者之间的区别了,
数据库是软件开发的核心和基础,一定要学好。
 

Sql server left join,right join和inner join的比较的更多相关文章

  1. SQL Server的三种物理连接之Hash Join(三)

    简介 在 SQL Server 2012 在一些特殊的例子下会看到下面的图标: Hash Join分为两个阶段,分别为生成和探测阶段. 首先是生成阶段,将输入源中的每一个条目经过散列函数的计算都放到不 ...

  2. SQL Server的三种物理连接之Merge join(二)

    简介 merge join 对两个表在连接列上按照相同的规则排序,然后再做merge,匹配的输出. 下面这个动态图展示了merge join的详细过程. merge join示例 创建两个表 IF O ...

  3. SQL Server的三种物理连接之Loop Join(一)

    Sql Server有三种物理连接Loop Join,Merge Join,Hash Join, 当表之间连接的时候会选择其中之一,不同的连接产生的性能不同,理解这三种物理连接对性能调优有很大帮助. ...

  4. Sql Server 与 MySql 在使用 update inner join 时的区别

    Sql Server -- 不使用别名 UPDATE tb_User SET tb_User.pass = '' FROM tb_User usr INNER JOIN tb_Address addr ...

  5. 《SQL Server 2008从入门到精通》--20180703

    SELECT操作多表数据 关于连接的问题,在<SQL必知必会>学习笔记中已经讲到过,但是没有掌握完全,所以再学一下. JOIN连接 首先我们先来看一下最简单的连接.Products表和Ve ...

  6. SQL Server的Linked Servers

    文章搬运自:SQL Server的Linked Servers(链接) 参考引用一下,感谢作者~ 我们在使用SQL Server时,有时会有这种需求,需要从一个SQL Server服务器A中,查询另一 ...

  7. SQL Server的Linked Servers(链接)

    我们在使用SQL Server时,有时会有这种需求,需要从一个SQL Server服务器A中,查询另一个SQL Server服务器B中的表,然后将SQL Server服务器A中的表和SQL Serve ...

  8. SQL Server Join方式

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

  9. 浅谈SQL Server中的三种物理连接操作(HASH JOIN MERGE JOIN NESTED LOOP)

    简介 在SQL Server中,我们所常见的表与表之间的Inner Join,Outer Join都会被执行引擎根据所选的列,数据上是否有索引,所选数据的选择性转化为Loop Join,Merge J ...

  10. SQL Server中INNER JOIN与子查询IN的性能测试

    这个月碰到几个人问我关于"SQL SERVER中INNER JOIN 与 IN两种写法的性能孰优孰劣?"这个问题.其实这个概括起来就是SQL Server中INNER JOIN与子 ...

随机推荐

  1. android Webview Html5 相关文章

    Android WebView的使用集锦(支持Html5) http://blog.csdn.net/l_215851356/article/details/69239643 WebView详解与简单 ...

  2. spring boot 使用不同的profile来加载不同的配置文件

    在开发过程之中,经常需要在开发和测试环境中进行互相切换,当切换的同时需要加载相应的配置文件,因此要经常 性的对配置文件进行相应的修改,长此以往感到十分痛苦.如果能针对开发和测试环境分别建两个不同的配置 ...

  3. git的使用总结【干货·转载】

    源文地址:https://juejin.im/post/5a54386af265da3e3b7a6317 摘抄: 版本树 / graph / network 干净简洁清晰 提交信息明确 易维护易读 举 ...

  4. mvc3 RenderAction传参问题

    我在viewA中调用部分视图viewB代码如下:@{Html.RenderAction("NewsList","News",new{pageSize=13, c ...

  5. Java 中的静态嵌套类和非静态嵌套类

    Java 中的静态嵌套类和非静态嵌套类 术语:嵌套类分为两类:静态嵌套类和非静态嵌套类.声明 static 的嵌套类称为静态嵌套类,非静态嵌套类也称为内部类. class OuterClass { p ...

  6. (17) go 协程管道

    一.协程 二.管道

  7. 【UOJ 34】 多项式乘法 (FFT)

    [题意] 给你两个多项式,请输出乘起来后的多项式. 先打一个递归版本的模板... #include<cstdio> #include<iostream> #include< ...

  8. WebLogic Server

    前几天,看了几集J2ee , 给我的感觉就是,看不懂!! 一点也不懂! 那怎么办呢? 听老师的,不管懂不懂,先看看再说.接下来,就开始了J2ee "艰苦"的历程.在J2ee中,经常 ...

  9. SPOJ1557 GSS2

    不知道第几次回顾了,每次回顾感觉都有新的收获 这题YYZ认为非常的简单,我们一起去%%%她吧(洛谷$id: 54050$) 题面 给出$n$个数,有$q$个询问,求最大子段和,注意相同的数只算一次 做 ...

  10. BZOJ3289[JZYZOJP2018]: Mato的文件管理 莫队+树状数组+离散化

            描述 Description     Mato同学从各路神犇以各种方式(你们懂的)收集了许多资料,这些资料一共有n份,每份有一个大小和一个编号.为了防止他人偷拷,这些资料都是加密过的, ...