oracle查询包含在子表中的主表数据

 Oracle数据库,查询某表中包含在子表中的数据,子表中数据按特定条件来源于该父表,SQL命令如数据库

select * from a_table a where a.commandId in (select commandId from b_table where type = 1)

 

a_table父表,b_table子表,a和b表都有commandId列,a表的commandId主键关联b表中的外键commandId,要求a表中commandId包含在b表commandId中,且b表的type黑白名单类型为1的数据spa

(即查出b表存在的关联的a表的数据)3d

也能够用:(仅限于一对一的状况,一对多会出现主表重复的状况)code

select * from a_table a,b_table b where a.commandId =b.commandId (+) and b.commandId is not null and b.type = 1;

如(一对多出现的问题):blog

 

 

或者是排序

select * from a_table a where exists(select 1 from b_table b where b.commandId =a.commandId where b.type = 1)table

 

有关in和exists的区别:class

“EXISTS,Oracle会首先检查主查询,而后运行子查询直到它找到第一个匹配项。IN,在执行子查询以前,系统先将主查询挂起,待子查询执行完毕,存放在临时表中之后再执行主查询。select

 

一、UNION (无重并集):当执行UNION 时,自动去掉结果集中的重复行,并以第一列的结果进行升序排序。command

二、UNION ALL (有重并集):不去掉重复行,而且不对结果集进行排序。

三、INTERSECT  (交集):取两个结果集的交集,而且以第一列的结果进行升序排列。

      select   id,name,job  from worker 
      INTERSECT
      select  empno,ename,job  fromemp;

四、MINUS  (差集):只显示在第一个集合中存在,在第二个集合中不存在的数据。而且以第一列的结果进行升序排序。

 

所以,还有一种写法:

select * from a_table a where a.commandId in (select commandId from a_table intersect select commandId from b_table)

相关文章
相关标签/搜索