设为首页 加入收藏

TOP

Oracle表连接——处理连接过程中另外一张表没有相关数据不显示问题
2015-08-31 19:59:34 来源: 作者: 【 】 浏览:51
Tags:Oracle 连接 处理 过程 另外 张表 没有 相关 数据 显示 问题

  一个数据表基本上很难满足我们的查询要求,同时,将所有的数据都保存在一个表格中显然也不是一种好的数据库设计,为了避免数据的冗余,删除、更新异常,我们通常需要建立一张外键表,通过表连接,来获取我们自己想要得到的数据,所以在数据查找中,表连接是一个经常使用到的操作,下面我们来看看两个或者几个表有哪些方式是可以连接的。


  经常遇到的问题:我们或许在表连接的过程中用于连接的另外一张表数据为空,导致某些数据得不到。我们要怎么解决呢?????


  我们就先从介绍表连接的方式开始,在介绍的过程中,就会得到解决。


假如我们有下面两张数据表


请看 "Persons" 表:


请注意,"Id_P" 列是 Persons 表中的的主键。这意味着没有两行能够拥有相同的 Id_P。即使两个人的姓名完全相同,Id_P 也可以区分他们。


接下来请看 "Orders" 表:


请注意,"Id_O" 列是 Orders 表中的的主键,同时,"Orders" 表中的 "Id_P" 列用于引用 "Persons" 表中的人,而无需使用他们的确切姓名。


请留意,"Id_P" 列把上面的两个表联系了起来。


方式1:根据两个或多个表中的列之间的关系


  我们可以通过引用两个表的方式,从两个表中获取数据:


  谁订购了产品,并且他们订购了什么产品?


结果集:


  这个方式看起来很直观,也是我们经常比较常用的,但没办法解决上面的问题,但是我们可以使用下面的join方式解决。


方式2:join


1)、SQL INNER JOIN 关键字


  注释:INNER JOIN 与 JOIN 是相同的。


  现在,我们希望列出所有人的定购。


  您可以使用下面的 SELECT 语句:


结果集:


  INNER JOIN 关键字在表中存在至少一个匹配时返回行。如果 "Persons" 中的行在 "Orders" 中没有匹配,就不会列出这些行。


  LEFT JOIN 关键字会从左表 (table_name1) 那里返回所有的行,即使在右表 (table_name2) 中没有匹配的行。(可以解决上面的问题


  注释:在某些数据库中, LEFT JOIN 称为 LEFT OUTER JOIN。


  现在,我们希望列出所有的人,以及他们的定购 - 如果有的话。


  您可以使用下面的 SELECT 语句:


结果集:


  LEFT JOIN 关键字会从左表 (Persons) 那里返回所有的行即使在右表 (Orders) 中没有匹配的行


  RIGHT JOIN 关键字会右表 (table_name2) 那里返回所有的行,即使在左表 (table_name1) 中没有匹配的行。


  注释:在某些数据库中, RIGHT JOIN 称为 RIGHT OUTER JOIN。


  现在,我们希望列出所有的定单,以及定购它们的人 - 如果有的话。


  您可以使用下面的 SELECT 语句:


结果集:


  RIGHT JOIN 关键字会从右表 (Orders) 那里返回所有的行即使在左表 (Persons) 中没有匹配的行


只要其中某个表存在匹配,FULL JOIN 关键字就会返回行。


  注释:在某些数据库中, FULL JOIN 称为 FULL OUTER JOIN。


  现在,我们希望列出所有的人,以及他们的定单,以及所有的定单,以及定购它们的人。


  您可以使用下面的 SELECT 语句:


结果集:


FULL JOIN 关键字会从左表 (Persons) 和右表 (Orders) 那里返回所有的行。如果 "Persons" 中的行在表 "Orders" 中没有匹配,或者如果 "Orders" 中的行在表 "Persons" 中没有匹配,这些行同样会列出


】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
分享到: 
上一篇MySQL数据库编码集设置为utf8 下一篇Linux下静默安装Oracle

评论

帐  号: 密码: (新用户注册)
验 证 码:
表  情:
内  容: