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)