自然左右外联接的区别

原创 2008年11月04日 20:22:00

在 FROM 子句中指定外联接时,可以由下列几组关键字中的一组指定:

LEFT JOIN 或 LEFT OUTER JOIN。
左向外联接的结果集包括 LEFT OUTER 子句中指定的左表的所有行,而不仅仅是联接列所匹配的行。如果左表的某行在右表中没有匹配行,则在相关联的结果集行中右表的所有选择列表列均为空值。

RIGHT JOIN 或 RIGHT OUTER JOIN。
右向外联接是左向外联接的反向联接。将返回右表的所有行。如果右表的某行在左表中没有匹配行,则将为左表返回空值。

FULL JOIN 或 FULL OUTER JOIN。
完整外部联接返回左表和右表中的所有行。当某行在另一个表中没有匹配行时,则另一个表的选择列表列包含空值。如果表之间有匹配行,则整个结果集行包含基表的数据值。

仅当至少有一个同属于两表的行符合联接条件时,内联接才返回行。内联接消除与另一个表中的任何行不匹配的行。而外联接会返回 FROM 子句中提到的至少一个表或视图的所有行,只要这些行符合任何 WHERE 或 HAVING 搜索条件。将检索通过左向外联接引用的左表的所有行,以及通过右向外联接引用的右表的所有行。完整外部联接中两个表的所有行都将返回。

 

现在假设有学生表,学生课程分数表

 

完整文字 c_id s_id subject acc
编辑 删除 1 1 语文 98
编辑 删除 2 1 数学 90
编辑 删除 3 2 英语 2

 

完整文字 ids name gender
编辑 删除 1 小明
编辑 删除 2 小华
编辑 删除 3 小兰
编辑 删除 4 小军

 

SELECT *
FROM acc
LEFT JOIN student ON s_id = ids
LIMIT 0 , 30
 
执行结果:
 
c_id s_id subject acc ids name gender
1 1 语文 98 1 小明
2 1 数学 90 1 小明
3 2 英语 2 2 小华

 

 

SELECT *
FROM acc
RIGHT JOIN student ON s_id = ids
LIMIT 0 , 30
 
结果
 
c_id s_id subject acc ids name gender
1 1 语文 98 1 小明
2 1 数学 90 1 小明
3 2 英语 2 2 小华
NULL NULL NULL NULL 3 小兰
NULL NULL NULL NULL 4 小军
 
 
得出以下结论: 所谓左表也就是你from的表,右表就是你join的表
leftjion 的意思就是以左表的纪录为准,反之rightjoin
还想说说啥时候用,也就是说,俩个表的数据不对称的时候用,
可能基础了点,但是越基础越重要么
版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

Launcher 壁纸随着左右滑动,临界时自然过渡

1.       Workspace.java 的修改实现左右循环滑动、壁纸在循环滑动时的平滑过渡 一> 壁纸在循环滑动时的平滑过渡 方法1: 通过研究代码发现每次在onTouchEven...

自然语言和形式语言 (包含各种术语的区别)

原文地址:http://learn.akae.cn/media/intro.naturalformal.html 自然语言(Natural Language)就是人类讲的语言,比如汉语、英语...

Join操作基本及区别:外连接、自然连接、内连接

Join操作基本Join操作基本分为3大类:外连接(细分为:左连接、右连接、全连接)、自然连接、内连接 。

SQL左右连接中的on and和on where的区别

原先一直对SQL左右连接中的on and和on where的区别不是太了解,直到在网上看到了下面这段话才豁然开朗。         在使用left join时,on and和on where条件...

Oracle 左右外连接的区别

忙中抽空。弄点记录。。。数据表的连接有: 1、内连接(自然连接): 只有两个表相匹配的行才能在结果集中出现 2、外连接: 包括 (1)左外连接 (左边的表不加限制) (2)右外连接(右边的表不加限制)...

SQL左右连接中的on and和on where的区别

原先一直对SQL左右连接中的on and和on where的区别不是太了解,直到在网上看到了下面这段话才豁然开朗。         在使用left join时,on and和on where条件的区...

mysql中char和varchar的 左右空格区别

都知道mysql中char和varchar的区别: 1、char是固定长度的,如果长度不足,采用右补空格的方式来填充字符串至规定的长度,而varchar不是,有多长存多长。 2、对于检索效...
  • huithe
  • huithe
  • 2012-08-01 14:34
  • 1260

SQL连接查询2 外连接(左右联接查询)

外连接主要包括左连接、右连接和完整外部连接。 1)左连接:Left Join 或 Left Outer Join       左连接的结果集包括LEFT OUTER子句中指定的左表的所有行...

SQL连接查询2 外连接(左右联接查询)

外连接主要包括左连接、右连接和完整外部连接。   1)左连接:Left Join 或 Left Outer Join       左连接的结果集包括LEFT OUTER子句中指定的左表的所有...

网站SEO优化如何入手才能让外链显得更自然有用

网站SEO优化如何入手才能让外链显得更自然有用 如何才能让外链建设显得更加的自然呢,什么样的外链才是优质的外链呢。  虽然现在搜索引擎一直在打击网站外链建设,但是大家都明白一点,那就是...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)