数据说明:

select * from dave;
ID  NAME
8 安庆
1 dave
2 bl
1 bl
2 dave
3 dba
4 sf-express
5 dmm
select * from b1;
ID  NAME
1 dave
2 bl
3 big bird
4 exc
9 怀宁

1. inner join(join)

   join默认为inner join.

以下3种写法的效果是一致的:

select * from dave a inner join b1 b on a.id = b.id;
select * from dave a join b1 b on a.id = b.id;
select * from dave a, b1 b where a.id = b.id;
ID  NAME      ID  NAME
1 dave 1 dave
2 bl 2 b1
1 bl 1 dave
2 dave 2 b1
3 dba 3 big bird
4 sf-express 4 exc

自然连接natural join

寻找数据类型和列名相同的字段,自动将他们连接起来,并返回所有符合条件的结果。

下面两种写法的效果是一致的:

select * from dave a natural join b1 b;
select a.id, b.name from dave a join b1 b on a.id = b.id and a.name = b.name;

ID  NAME
1 dave
2 bl

注意:1. 如果自然连接的两个表有多个字段满足相同名称和类型,则会作为自然链接的条件

   2. 如果数据类型不同,则会报错。

2. Outer join

LEFT JOIN /RIGHT JOIN/FULL JOIN. 通常省略OUTER。

(+)也可以用来表示外连接。

(一)+操作符只能在where子句中,不能与outer join同时使用。

(二)+操作符只能执行外连接,如果在where中包含多个条件,则所有条件都包含+操作符。

(三)+操作符只适用于列,而不能用在表达式上。

(四)+操作符不能与or in操作符一起使用。

(五)操作符只能用于实现左外连接和右外连接,不能用于全外连接。

2.1 左外连接left join +

+ 表示补充,哪个个表有加号,这个表就是匹配表。所以加号写在右表,左表就是全部显示,故是左连接。

以下三种写法的效果是一致的:

select * from dave a left join b1 b on a.id = b.id;
select * from dave a left outer join b1 b on a.id = b.id;
select * from dave a ,b1 b where a.id = b.id(+); ID  NAME     ID  NAME
1 bl       1 dave
1 dave    1 dave
3 dba     3 big bird
4 sf-express   4 exc
2 dave     2 bl
2 bl      2 bl
5 dmm   --没有匹配到,为null
8 安庆  --没有匹配到,为null

2.2 右外连接right join +

以下三种写法的效果是一致的:

select * from dave a right join b1 b on a.id = b.id;
select * from dave a right outer join b1 b on a.id = b.id;
select * from dave a ,b1 b where a.id(+) = b.id; ID NAME      ID NAME
1 dave     1 dave
2 bl       2 bl
1 bl       1 dave
2 dave      2   bl
3 dba      3 big bird
4 sf-express 4 exc
9 怀宁        --没有匹配到,为null

2.3 全外连接(full outer join/full join)

左表和右表都不做限制,所有的记录都显示,两表不足的地方用null填充。全外连接不支持(+)这种写法。

select * from dave a full join b1 b on a.id = b.id;

ID   NAME    ID  NAME
8 安庆   --NULL
1 dave       1 dave
2 bl         2 bl
1 bl         1 dave
2 dave       2 bl
3 dba      3 big bird
4 sf-express 4 exc
5 dmm --NULL
--NULL      9 怀宁

---------20161125补充内容:

insert into b1 values('','test');

insert into b1 values('','test02');

select * from dave left join b1 on dave.id = b1.id;
   ID    NAME          ID   NAME
1 bl        1 dave
1 dave       1   dave
2 dave       2 b1
2 bl        2 b1
3 dba        3 big bird
4 sf-express    4 exc
1 bl        1 test
1 dave        1 test
1 bl        1 test02
1 dave        1 test02
5 dmm null
8 安庆    null

ORACLE 各种连接的更多相关文章

  1. Oracle 左连接、右连接、全外连接、(+)号作用

    分类: Oracle Oracle  外连接 (1)左外连接 (左边的表不加限制)       (2)右外连接(右边的表不加限制)       (3)全外连接(左右两表都不加限制) 外连接(Outer ...

  2. ArcGis设置到 Oracle 的连接

    设置到 Oracle 的连接 地理数据 » 管理地理数据库 » Oracle 中的地理数据库 要建立从客户端计算机到 Oracle 数据库的连接,必须在客户端计算机上安装 Oracle 客户端应用程序 ...

  3. Oracle 左连接、右连接、全外连接、(+)号作用、inner join(等值连接) (转载)

    Oracle  外连接 (1)左外连接 (左边的表不加限制)       (2)右外连接(右边的表不加限制)       (3)全外连接(左右两表都不加限制) 外连接(Outer Join) oute ...

  4. [转]使用Navicat for Oracle工具连接oracle的

    使用Navicat for Oracle工具连接oracle的 这是一款oracle的客户端的图形化管理和开发工具,对于许多的数据库都有支持.之前用过 Navicat for sqlserver,感觉 ...

  5. Oracle 表连接方式分析 .

    一 引言 数据仓库技术是目前已知的比较成熟和被广泛采用的解决方案,用于整和电信运营企业内部所有分散的原始业务数据,并通过便捷有效的数据访问手段,可以支持企业内部不同部门,不同需求,不同层次的用户随时获 ...

  6. Oracle左连接、右连接、全外连接

    Oracle  外连接 (1)左外连接 (左边的表不加限制)(2)右外连接(右边的表不加限制)(3)全外连接(左右两表都不加限制) 外连接(Outer Join) outer join则会返回每个满足 ...

  7. oracle表连接------>排序合并连接(Merge Sort Join)

    排序合并连接 (Sort Merge Join)是一种两个表在做连接时用排序操作(Sort)和合并操作(Merge)来得到连接结果集的连接方法. 对于排序合并连接的优缺点及适用场景例如以下: a,通常 ...

  8. Oracle左连接、右连接、全外连接以及(+)号用法(转)

    +:与附带的字段相连,和“+”相连的字段值,不管是否存在,都会展示 也就是带上相连接的字段 有数据了就显示,没数据就显示为null Oracle  外连接(OUTER JOIN) 左外连接(左边的表不 ...

  9. Oracle左连接,右连接

    Oracle左连接,右连接 数据表的连接有: 1.内连接(自然连接): 只有两个表相匹配的行才能在结果集中出现 2.外连接: 包括 (1)左外连接(左边的表不加限制) (2)右外连接(右边的表不加限制 ...

  10. 理解oracle中连接和会话

    详见:http://blog.yemou.net/article/query/info/tytfjhfascvhzxcytp44 理解oracle中连接和会话 1.  概念不同:概念不同: 连接是指物 ...

随机推荐

  1. springMVC中实现servlet依赖注入

    记录一下开发过程中遇到的问题: 首先看一下这个帖子: http://blog.csdn.net/gaogaoshan/article/details/23540129 由于我使用的是springMVC ...

  2. fuelphp 问题1

    fuelphp遇到的一些小问题,写下来以防止别人遇到相同的问题,写的比较随意 1.引用到orm\model 报错:class Model_Test extends Orm\Model 报错内容:Cla ...

  3. Kingsoft Office Writer 2012 8.1.0.3385 - (.wps) Buffer Overflow Exploit (SEH)

    #!/usr/bin/python # Exploit Title: Kingsoft Office Writer v2012 8.1.0.3385 .wps Buffer Overflow Expl ...

  4. Android apk集成

    刚开始学习Android,对很多东西都不懂,所以以下是我做的第一件事,记录一下,也就是apk的集成: 我们集成的apk是已经签过名的第三方apk,并且需要集成到system/priv-app目录下,过 ...

  5. MicroERP软件更新记录1.0

    版本号:1.0.256 本次: 1\修复了选择货位时的BUG; 2\增加了物品资料由EXCEL表批量导入的功能; 3\物品资料增加了三个自定义属性; 4\优化了科目汇总账(余额表)算法; 5\应大家建 ...

  6. 最简单的RASPBERRY PI wifi配置

    Setting up Wifi with the Command Line  SIMON MONK   This tutorial works best if your router is broad ...

  7. Tyvj 题目1463 智商问题(分块)

    P1463 智商问题 时间: 1500ms / 空间: 131072KiB / Java类名: Main 背景 各种数据结构帝~各种小姊妹帝~各种一遍AC帝~ 来吧! 描述 某个同学又有很多小姊妹了他 ...

  8. cookie怎么用

    cookie是什么? cookie是浏览器提供的一种机制,它将document 对象的cookie属性提供给JavaScript.可以由JavaScript对其进行控制,而并不是JavaScript本 ...

  9. 柏克EPS应急电源签约联达大厦保安全

    近日,柏克EPS应急电源成功签约佛山市联达大厦,保障大厦电力安全. 佛山市联达大厦占地6674㎡,总建筑面积约4.6万㎡,设有两层地下室,提供201个停车位,地面29层.大厦大楼分为主楼和副楼,主楼地 ...

  10. Number of 1 Bits(Difficulty: Easy)

    题目: Write a function that takes an unsigned integer and returns the number of ’1' bits it has (also ...