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的數據
(即查出b表存在的關聯的a表的數據)
也可以用:(僅限於一對一的情況,一對多會出現主表重復的情況)
select * from a_table a,b_table b where a.commandId =b.commandId (+) and b.commandId is not null and b.type = 1;
如(一對多出現的問題):
或者是
select * from a_table a where exists(select 1 from b_table b where b.commandId =a.commandId where b.type = 1)
有關in和exists的區別:
“EXISTS,Oracle會首先檢查主查詢,然后運行子查詢直到它找到第一個匹配項。IN,在執行子查詢之前,系統先將主查詢掛起,待子查詢執行完畢,存放在臨時表中以后再執行主查詢。
1、UNION (無重並集):當執行UNION 時,自動去掉結果集中的重復行,並以第一列的結果進行升序排序。
2、UNION ALL (有重並集):不去掉重復行,並且不對結果集進行排序。
3、INTERSECT (交集):取兩個結果集的交集,並且以第一列的結果進行升序排列。
select id,name,job from worker
INTERSECT
select empno,ename,job fromemp;
4、MINUS (差集):只顯示在第一個集合中存在,在第二個集合中不存在的數據。並且以第一列的結果進行升序排序。
因此,還有一種寫法:
select * from a_table a where a.commandId in (select commandId from a_table intersect select commandId from b_table)