left join ,right join ,inner join 都是怎么交的?

1.left join 从字面上来看,即为左交,是以左表为基准的,右表通过相应字段的连接来联合的。

A表

id     name

1      张三

2      李四

3      王五

4      小陈

B表

id      job

1         厨师

2         教师

3         工人

5        工程师

select * from a left join  b on a.id=b.id

结果是这样的:

id     name      id      job

1      张三     1         厨师

2      李四    2         教师

3      王五     3         工人

4      小陈    null      null

left join 是左表全部显示,右表显示匹配到的字段和值,匹配不到的用NULL显示。

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

2.right join

right join 从字面上来看,即为右交,是以右表为基准的,左表通过相应字段的连接来联合的。

还以上面例子为例:

select * from a left join b  on a.id=b.id

显示的结果可想而知:

id     name      id      job

1      张三     1         厨师

2      李四    2         教师

3      王五     3         工人

null    null     5        工程师

right join 是右表全部显示,左表显示匹配到的字段和值,匹配不到的用NULL显示。

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

3.inner join 从字面上来看,即为内交,内链接。内交是通过连接相等字段来执行的。

仍以上面例子为例:

select * from a Inner join b  on a.id=b.id

结果是这样的:

id     name      id      job

1      张三     1         厨师

2      李四    2         教师

3      王五     3         工人

inner join 是不以左右表为基准来匹配的,而是通过相等字段来链接值形成表的.

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

在现实应用中,inner join 的速度是远远高于left join 和 right join的,但是具体的使用情况还得看数据的需求。

时间: 2024-08-29 04:50:17

left join ,right join ,inner join 都是怎么交的?的相关文章

SQL Tuning 基础概述06 - 表的连接方式:Nested Loops Join,Merge Sort Join & Hash Join

nested loops join 嵌套循环 merge sort join 排序合并 hash join 哈希连接 nested loops join(嵌套循环)   驱动表返回几条结果集,被驱动表访问多少次,有驱动顺序,无须排序,无任何限制. 驱动表限制条件有索引,被驱动表连接条件有索引. hints:use_nl() merge sort join(排序合并)   驱动表和被驱动表都是最多访问1次,无驱动顺序,需要排序(SORT_AREA_SIZE),连接条件是<>或like导致无法使用

深入理解Oracle表(3):三大表连接方式详解之Nested loop join和 Sort merge join

深入理解Oracle表(3):三大表连接方式详解之Nested loop join和 Sort merge join 分类: Oracle 基础管理 Oracle SQL 开发2013-01-28 00:33 2536人阅读 评论(1) 收藏 举报 关系数据库技术的精髓就是通过关系表进行规范化的数据存储       并通过各种表连接技术和各种类型的索引技术来进行信息的检索和处理       这里Think愿意和大家一起来学习分享Oracle的三大表连接技术              在早期版本,

一步一步跟我学习lucene(18)---lucene索引时join和查询时join使用示例

了解sql的朋友都知道,我们在查询的时候可以采用join查询,即对有一定关联关系的对象进行联合查询来对多维的数据进行整理.这个联合查询的方式挺方便的,跟我们现实生活中的托人找关系类似,我们想要完成一件事,先找自己的熟人,然后通过熟人在一次找到其他,最终通过这种手段找到想要联系到的人.有点类似于"世间万物皆有联系"的感觉. lucene的join包提供了索引时join和查询时join的功能: Index-time join 大意是索引时join提供了查询时join的支持,且IndexWr

SQL JOIN\SQL INNER JOIN 关键字\SQL LEFT JOIN 关键字\SQL RIGHT JOIN 关键字\SQL FULL JOIN 关键字

SQL join 用于根据两个或多个表中的列之间的关系,从这些表中查询数据. Join 和 Key 有时为了得到完整的结果,我们需要从两个或更多的表中获取结果.我们就需要执行 join. 数据库中的表可通过键将彼此联系起来.主键(Primary Key)是一个列,在这个列中的每一行的值都是唯一的.在表中,每个主键的值都是唯一的.这样做的目的是在不重复每个表中的所有数据的情况下,把表间的数据交叉捆绑在一起. 请看 "Persons" 表: Id_P LastName FirstName

left join 和 left outer join 的区别的总结

个人通俗的讲:   A   left   join   B   的连接的记录数与A表的记录数同   A   right   join   B   的连接的记录数与B表的记录数同   A   left   join   B   等价B   right   join   A   table   A: Field_K,   Field_A   1                       a   3                       b   4                       

join中级篇---------hash join &amp; merge join &amp; nested loop Join

嵌套循环连接(Nested Loop Join) 循环嵌套连接是最基本的连接,正如其名所示那样,需要进行循环嵌套,嵌套循环是三种方式中唯一支持不等式连接的方式,这种连接方式的过程可以简单的用下图展示: 图1.循环嵌套连接的第一步 图2.循环嵌套连接的第二步 由上面两个图不难看出,循环嵌套连接查找内部循环表的次数等于外部循环的行数,当外部循环没有更多的行时,循环嵌套结束.另外,还 可以看出,这种连接方式需要内部循环的表有序(也就是有索引),并且外部循环表的行数要小于内部循环的行数,否则查询分析器就

SQL的JOIN语法解析(inner join, left join, right join, full outer join的区别)

原文链接:http://www.powerxing.com/sql-join/ 总的来说,四种JOIN的使用/区别可以描述为: left join 会从左表(shop)那里返回所有的记录,即使在右表(sale_detail)中没有匹配的行. right outer join 右连接,返回右表中的所有记录,即使在左表中没有记录与它匹配 full outer join 全连接,返回左右表中的所有记录 在表中存在至少一个匹配时,inner join 返回行. 关键字inner可省略. 具体可以看sta

关于sql server中的 jion,inner join, left join ,left outer join, right join,right outer join 的几点使用心得

平时我们做关联,一般都是2~3张表,不太关注这样繁杂的写法,那今天咱们就看看这些写法吧 对将要说的这三种,先说一下要介绍的要点:on后面的条件可以放几个?什么时候结合着where条件一起使用? 大家可以先看看这个帖子,帖子的名字是:sqlserver left join的on中如何添加多个查询条件?? 链接:http://bbs.csdn.net/topics/270023422 开始咱们的介绍吧 首先对于join 分三块: 1.  join .join inner (内联) 我们平时的写法是:

oracle--left join and 和left join where的区别

开发程序时,经常会遇到left join,inner join的语句,Join是关系型数据库系统的重要操作之一,相对来说速度要快一些,所以大家一般都会优先选择join语句. 但是在做程序时,对于join的一些用法却不一定很清晰.今天给大家讲的是left join and 和left join where. ?数据库在通过连接两张或多张表来返回记录时,都会生成一张中间的临时表,然后再将这张临时表返回给用户. 在使用left jion on时,and和where条件的区别如下: 1. on条件是在生