亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定

子查詢中的空值問題,最后這點有點不明白

select mgr from emp where mgr is not null->得出的結果是除了king以外的全部老板,然后select * from emp where empno not in(select mgr from emp where mgr is not null)->得出的不應該是全部非老板的員工加上king這個員工嗎?

正在回答

2 回答

SQL>?select?distinct?mgr?from?emp?where?mgr?is?not?null;?
??????MGR
??????----------?
?????????7839
?????????7782???????????
?????????7698
???????????7902
?????????7566
?????????7788
已選擇6行。

用distinct可以找到不重復記錄,

select?distinct?mgr?from?emp?where?mgr?is?not?null;

上面這條語句的功能可以找到所有老板。很明顯King(7839)是包括在里面的,為什么select * from emp where empno not in(select mgr from emp where mgr is not null)得到的記錄不包括King而只是全部非老板員工呢?那是因為對比查找的時候,King這個人并沒有被排除,當用他的empno對比上面6個數據時,自然會匹配到7839(King),從而被排除。故最終結果只會輸出8個非老板員工(即全部員工剪去上面6個老板員工)。

1 回復 有任何疑惑可以回復我~

子查詢排除的是king這個員工, 但是king下面有員工, 就是說king的員工號(deptno)已經在mgr里面了, 所以最終查詢會排除king的員工號

0 回復 有任何疑惑可以回復我~

舉報

0/150
提交
取消
Oracle高級查詢
  • 參與學習       62979    人
  • 解答問題       148    個

數據庫開發中應用廣泛的高級查詢,本教程通過大量的案例詳細講解

進入課程

子查詢中的空值問題,最后這點有點不明白

我要回答 關注問題
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號