Oracle join的实际应用代码介绍

数据库 Oracle
以下的文章主要是介绍Oracle join的用法,其中包括内连接,以及左连接的相关内容的介绍,以下就是相关内容的描述。

本文主要是通过介绍Oracle join的相关实际应用代码来引出Oracle join的用法,如果你在Oracle join的用法中存在一些不解之处时,你就可以妨浏览下面的文章,希望你能从中获得自己想要的东西。

8i:

 

  1. create table dali.test1(a int,b int);  
  2. create table dali.test2(a int,b int);  
  3. insert into dali.test1 values(1,456);  
  4. insert into dali.test1 values(2,427);  
  5. insert into dali.test2 values(1,45456);  
  6. insert into dali.test2 values(3,45656);   

 

内连接

  1. select * from dali.test1 a, dali.test2 b where a.a=b.a; 

左连接

  1. select * from dali.test1 a, dali.test2 b where a.a=b.a(+); 

右连接

  1. select * from dali.test1 a, dali.test2 b where a.a(+)=b.a; 

完全连接

  1. select * from dali.test1 a, dali.test2 b where a.a=b.a(+)  
  2. union  
  3. select * from dali.test1 a, dali.test2 b where a.a(+)=b.a; 

迪卡尔

  1. select * from dali.test1, dali.test2; 

9i和sqlserver一样 left join,right join,full join

 

分为1. INNER JOIN 2. LEFT JOIN 3. RIGHT JOIN 4.LEFT OUTER JOIN

首先设定一个我们要用的两个表

表A 表B

ID NAME ID CLASS

1 IBM 1 C1

2 SONY 3 C3

3 BMW 4 C4

1 INNER JOIN: SELECT * FROM A INNER JOIN B ON A.ID=B.ID

得表 ID NAME CLASS

1 IBM C1

3 BMW C3

对了 就是 两个表的ID都存在并相同 得到这两个表的组合表

2 LEFT JOIN : SELECT * FROM A LEFT JOIN B ON A.ID=B.ID

得表 ID NAME CLASS

1 IBM C1

2 SONY null

3 BMW C3

Oracle join的用法中如果还有方向感 就行 LEFT(左) 得到的是A(left语句的左边的表)的所有记录 而B表对应的记录没有的话也要补齐 (真霸道! 呵呵)

3 RIGHT JOIN : SELECT * FROM A RIGHT JOIN B ON A.ID=B.ID

得表 ID NAME CLASS

1 IBM C1

3 BMW C3

4 null C4

对了RIGHT(右) 得到的是B(right语句的右边的表)的所有记录 而A表对应的记录没有的话也要补齐 (我也翻身了! 呵呵)

4 FULL OUTER JOIN: SELECT * FROM A FULL OUTER JOIN B ON A.ID=B.ID

得表 ID NAME CLASS

1 IBM C1

2 SONY null

3 BMW C3

4 null C4

以上的相关内容就是对Oracle join的用法的介绍,望你能有所收获。

【编辑推荐】

  1. Oracle to_char的用法描述
  2. 创建Oracle procedure并调用在pl/sql里
  3. Oracle存储过程的用法简介
  4. Oracle数据库的重复数据删除技术的优势体现
  5. Oracle数据库里重复没有用的数据如何删除

 

责任编辑:佚名 来源: 博客园
点赞
收藏

51CTO技术栈公众号