浅谈sql连接查询的区别 inner,left,right,full

--table1 表

ID NAME QQ PHONE
1 秦云 10102800 13500000
2 在路上 10378 13600000
3 LEO 10000 13900000
4 秦云 0241458 54564512

--table2 表

ID NAME sjsj gly
1 秦云 2004-01-01 00:00:00.000 李大伟
2 秦云 2005-01-01 00:00:00.000 马化腾
3 在路上 2005-01-01 00:00:00.000 马化腾
4 秦云 2005-01-01 00:00:00.000 李大伟
5 在路上 2005-01-01 00:00:00.000 李大伟

--inner join   只要是符合要求的就显示

select * from table1 t1 

inner join table2 t2 on t1.name=t2.name<br><br>--得到的结果

ID NAME QQ PHONE ID NAME sjsj gly
1 秦云 10102800 13500000 1 秦云 2004-01-01 00:00:00.000 李大伟
4 秦云 0241458 54564512 1 秦云 2004-01-01 00:00:00.000 李大伟
1 秦云 10102800 13500000 2 秦云 2005-01-01 00:00:00.000 马化腾
4 秦云 0241458 54564512 2 秦云 2005-01-01 00:00:00.000 马化腾
2 在路上 10378 13600000 3 在路上 2005-01-01 00:00:00.000 马化腾
1 秦云 10102800 13500000 4 秦云 2005-01-01 00:00:00.000 李大伟
4 秦云 0241458 54564512 4 秦云 2005-01-01 00:00:00.000 李大伟
2 在路上 10378 13600000 5 在路上 2005-01-01 00:00:00.000 李大伟

--left join 以左表为主,会看到若右表有 关联字段重复,则 左边关联的字段信息翻倍。

select * from table1 t1                      (1)

left join table2 t2 on t1.name=t2.name

与

select * from table2 t2                      (2)

right join table1 t1 on t1.name=t2.name

结果相等,不过两表的顺序换一下而已。

(1)结果

ID NAME  QQ PHONE  ID NAME  sjsj  gly

1  秦云 10102800  13500000  1  秦云 2004-01-01 00:00:00.000 李大伟

1  秦云 10102800  13500000  2  秦云 2005-01-01 00:00:00.000 马化腾

1  秦云 10102800  13500000  4  秦云 2005-01-01 00:00:00.000 李大伟

2  在路上 10378  13600000  3  在路上 2005-01-01 00:00:00.000 马化腾

2  在路上 10378  13600000  5  在路上 2005-01-01 00:00:00.000 李大伟

3  LEO 10000  13900000  NULL  NULL  NULL  NULL

4  秦云 0241458 54564512  1  秦云 2004-01-01 00:00:00.000 李大伟

4  秦云 0241458 54564512  2  秦云 2005-01-01 00:00:00.000 马化腾

4  秦云 0241458 54564512  4  秦云 2005-01-01 00:00:00.000 李大伟

(2)结果

ID NAME  sjsj  gly ID NAME  QQ PHONE

1  秦云 2004-01-01 00:00:00.000 李大伟 1  秦云 10102800  13500000

2  秦云 2005-01-01 00:00:00.000 马化腾 1  秦云 10102800  13500000

4  秦云 2005-01-01 00:00:00.000 李大伟 1  秦云 10102800  13500000

3  在路上 2005-01-01 00:00:00.000 马化腾 2  在路上 10378  13600000

5  在路上 2005-01-01 00:00:00.000 李大伟 2  在路上 10378  13600000

NULL  NULL  NULL  NULL  3  LEO 10000  13900000

1  秦云 2004-01-01 00:00:00.000 李大伟 4  秦云 0241458 54564512

2  秦云 2005-01-01 00:00:00.000 马化腾 4  秦云 0241458 54564512

4  秦云 2005-01-01 00:00:00.000 李大伟 4  秦云 0241458 54564512

--left join 已右表为主 ,与left 同理

select * from table1 t1 

right join table2 t2 on t1.name=t2.name

ID NAME  QQ PHONE  ID NAME  sjsj  gly

1  秦云 10102800  13500000  1  秦云 2004-01-01 00:00:00.000 李大伟

4  秦云 0241458 54564512  1  秦云 2004-01-01 00:00:00.000 李大伟

1  秦云 10102800  13500000  2  秦云 2005-01-01 00:00:00.000 马化腾

4  秦云 0241458 54564512  2  秦云 2005-01-01 00:00:00.000 马化腾

2  在路上 10378  13600000  3  在路上 2005-01-01 00:00:00.000 马化腾

1  秦云 10102800  13500000  4  秦云 2005-01-01 00:00:00.000 李大伟

4  秦云 0241458 54564512  4  秦云 2005-01-01 00:00:00.000 李大伟

2  在路上 10378  13600000  5  在路上 2005-01-01 00:00:00.000 李大伟 

--full join  两表数据都取出来,不管是否符合

select * from table1 t1 

full join table2 t2 on t1.name=t2.name

结果

ID NAME  QQ PHONE  ID NAME  sjsj  gly

1  秦云 10102800  13500000  1  秦云 2004-01-01 00:00:00.000 李大伟

1  秦云 10102800  13500000  2  秦云 2005-01-01 00:00:00.000 马化腾

1  秦云 10102800  13500000  4  秦云 2005-01-01 00:00:00.000 李大伟

2  在路上 10378  13600000  3  在路上 2005-01-01 00:00:00.000 马化腾

2  在路上 10378  13600000  5  在路上 2005-01-01 00:00:00.000 李大伟

3  LEO 10000  13900000  NULL  NULL  NULL  NULL

4  秦云 0241458 54564512  1  秦云 2004-01-01 00:00:00.000 李大伟

4  秦云 0241458 54564512  2  秦云 2005-01-01 00:00:00.000 马化腾

4  秦云 0241458 54564512  4  秦云 2005-01-01 00:00:00.000 李大伟

以上就是小编为大家带来的浅谈sql连接查询的区别 inner,left,right,full全部内容了,希望大家多多支持我们~

(0)

相关推荐

  • 深入理解SQL的四种连接-左外连接、右外连接、内连接、全连接

    1.内联接(典型的联接运算,使用像 =  或 <> 之类的比较运算符).包括相等联接和自然联接.     内联接使用比较运算符根据每个表共有的列的值匹配两个表中的行.例如,检索 students和courses表中学生标识号相同的所有行.       2.外联接.外联接可以是左向外联接.右向外联接或完整外部联接.     在 FROM子句中指定外联接时,可以由下列几组关键字中的一组指定:     1)LEFT  JOIN或LEFT OUTER JOIN     左向外联接的结果集包括  LEF

  • sql 左连接和右连接的使用技巧(left join and right join)

    下面给一个例子进行说明: 例表a aid adate 1 a1 2 a2 3 a3 表b bid bdate 1 b1 2 b2 4 b4 left join: select * from a left join b on a.aid = b.bid 首先取出a表中所有数据,然后再加上与a,b匹配的的数据 此时的取出的是: 1 a1 b1 2 a2 b2 3 a3 空字符 同样的也有right join 指的是首先取出b表中所有数据,然后再加上与a,b匹配的的数据 此时的取出的是: 1 a1 b

  • SQL之left join、right join、inner join的区别浅析

    今天和某朋友聊天,谈到他们公司的一个小问题.如下: 表A设备表,存储MAC地址,省份,城市,区. 表B软件表,存储MAC地址,软件名字. 功能是可以按省份,城市,或者区来查询软件列表. 你猜它现在如何做的? 它通过省份,城市,或者区取得MAC地址,然后查询B表用in查询. 这个很明显是不合理的,处理这种多对多的关系,为什么不用多表联查呢? 链表的方法常用的有3个: (inner) join 内部等值连接.left join 左连接 和 right join右连接. 有什么区别呢?怎么用呢? 下面

  • 数据库中的左连接(left join)和右连接(right join)区别

    Left Join / Right Join /inner join相关 关于左连接和右连接总结性的一句话: 左连接 where只影向右表,右连接where只影响左表. Left Join select * from tbl1 Left Join tbl2 where tbl1.ID = tbl2.ID 左连接后的检索结果是显示tbl1的所有数据和tbl2 中满足where 条件的数据. 简言之 Left Join影响到的是右边的表 Right Join select * from tbl1 R

  • 浅谈sql连接查询的区别 inner,left,right,full

    --table1 表 ID NAME QQ PHONE 1 秦云 10102800 13500000 2 在路上 10378 13600000 3 LEO 10000 13900000 4 秦云 0241458 54564512 --table2 表 ID NAME sjsj gly 1 秦云 2004-01-01 00:00:00.000 李大伟 2 秦云 2005-01-01 00:00:00.000 马化腾 3 在路上 2005-01-01 00:00:00.000 马化腾 4 秦云 20

  • 浅谈MySQL模糊查询中通配符的转义

    sql中经常用like进行模糊查询,而模糊查询就要用到百分号"%",下划线"_"这些通配符,其中"%"匹配任意多个字符,"_"匹配单个字符.如果我们想要模糊查询带有通配符的字符串,如"60%","user_name",就需要对通配符进行转义,有两种方式.如下:   1.反斜杠是转义符,通过反斜杠来转义%,使其不再是通配符.这里第一个%是通配符,第二个%不是通配符. select perc

  • 浅谈MySQL数据查询太多会OOM吗

    目录 全表扫描对server层的影响 全表扫描对InnoDB的影响 InnoDB内存管理 小结 我的主机内存只有100G,现在要全表扫描一个200G大表,会不会把DB主机的内存用光? 逻辑备份时,可不就是做整库扫描吗?若这样就会把内存吃光,逻辑备份不是早就挂了? 所以大表全表扫描,看起来应该没问题.这是为啥呢? 全表扫描对server层的影响 假设,我们现在要对一个200G的InnoDB表db1. t,执行一个全表扫描.当然,你要把扫描结果保存在客户端,会使用类似这样的命令: mysql -h$

  • 浅谈RedisTemplate和StringRedisTemplate的区别

    目录 一.区别 二.问题总结 三.案例:springboot整合redis五种数据结构API 1.string(字符串)类型 2.hash(哈希)类型 3.list(列表)类型 4.set(无序集合)类型 5.zset(有序集合)类型 6.删除key 四.总结: 一.区别 区别点1:两者的关系是StringRedisTemplate继承RedisTemplate.RedisTemplate是一个泛型类,而StringRedisTemplate则不是. 区别点2:两者序列化策略不同, String

  • 浅谈cookie 和session 的区别

    具体来说 cookie 是保存在"客户端"的,而session是保存在"服务端"的 cookie 是通过扩展http协议实现的 cookie 主要包括 :名字,值,过期时间,路径和域: 如果cookie不设置生命周期,则以浏览器关闭而关闭,这种cookie一般存储在内存而不是硬盘上.若设置了生命周期则相反,不随浏览器的关闭而消失,这些cookie仍然有效直到超过设定的过 期 时间. session 一种类似散列表的形式保存信息, 当程序需要为某个客户端的请求创建一个

  • 浅谈Ajax和JavaScript的区别

    javascript是一种在浏览器端执行的脚本语言,Ajax是一种创建交互式网页应用的开发技术 ,它是利用了一系列相关的技术其中就包括javascript. Javascript是由网景公司开发的一种脚本语言,它和sun公司的java语言是没有任何关系的,它们相似的名称只是一种行销策略. 在一般的web开发中,javascript是在浏览器端执行的,我们可以用javascript控制浏览器的行为和内容. 在 Ajax应用中信息是如何在浏览器和服务器之间传递的. 通过XML数据或者字符串 以上这篇

  • 浅谈addEventListener和attachEvent的区别

    • addEventListener共有3个参数,如下所示: element.addEventListener(type,listener,useCapture); 参数 参数说明 element 要绑定事件的对象,及HTML节点. type 事件名称,注意去掉事件前边的"on",比如"onclick"要写成"click","onmouseover"要写成"mouseover". listener 要绑定的

  • java集合_浅谈Iterable和Iterator的区别

    1). Iterator是迭代器类,而Iterable是为了只要实现该接口就可以使用foreach,进行迭代. 2). Iterable中封装了Iterator接口,只要实现了Iterable接口的类,就可以使用Iterator迭代器了. 3). 集合Collection.List.Set都是Iterable的实现类,所以他们及其他们的子类都可以使用foreach进行迭代. 4). Iterator中和核心的方法next(),hasnext(),remove(),都是依赖当前位置,如果这些集合直

  • 浅谈toLowerCase和toLocaleLowerCase的区别

    ECMAScript中涉及字符串大小写转换的方法有4个:toLowerCase().toLocaleLowerCase().toUpperCase()和toLocaleUpperCase(). 其中,toLowerCase()和toUpperCase()是两个经典的方法,借鉴自java.lang.String中的同名方法.而toLocaleLowerCase()和toLocaleUpperCase()方法则是针对特定地区的实现. 对有些地区来说,针对地区的方法与其通用方法得到的结果相同,但少数语

  • 浅谈c++ 字符类型总结区别wchar_t,char,WCHAR

    1.区别wchar_t,char,WCHAR ANSI:即 char,可用字符串处理函数:strcat( ),strcpy( ), strlen( )等以str打头的函数. UNICODE:wchar_t是Unicode字符的数据类型,它实际定义在里: typedef unsigned short wchar_t; 另外,在头文件中有这样的定义:typedef wchar_t WCHAR; 所以WCHAR实际就是wchar_t wchar_t 可用字符串处理函数:wcscat(),wcscpy(

随机推荐