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的數據

(即查出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)

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章