在oracle的子查詢中使用some,any和all

用some,any和all對子查詢中返回的多行結果進行處理。下面我們來簡單介一下這幾個關鍵詞的含義。

  • Some在此表示滿足其中一個的意義,是用or串起來的比較從句。
  • Any也表示滿足其中一個的意義,也是用or串起來的比較從句,區別是any一般用在非“=”的比較關係中,這也很好理解,英文中的否定句中使用any肯定句中使用sone,這一點是一樣的。
  • All則表示滿足其其中所有的查詢結果的含義,使用and串起來的比較從句。

下面是一些例子

找出員工中,只要比部門號爲10的員工中的任何一個員工的工資高的員工的姓名個工資。也就是說只要比部門號爲10的員工中的那個工資最少的員工的工資高就滿足條件。

select ename,sal

From emp

Where sal > any(select sal from emp where deptno = 10);

這裏推薦用any,如果你非要用some也是沒有任何問題的,結果是一樣的,只是一般來講some用在“=”的比較從句中。

select ename,sal

From emp

Where sal > some(select sal from emp where deptno = 10);

上面的用法完全OK的。

select ename,sal

From emp

Where sal = some(select sal from emp where deptno = 30) and deptno not in (select deptno from emp where deptno = 30);

上面纔是some的正常用法。其含義是找到和30部門員工的任何一個人工資相同的那些員工。雖然沒有找到。

最後一個關鍵字all的用法也很簡單就是要與子查詢的每一結果都要匹配。

select ename,sal

From emp

Where sal > all(select sal from emp where deptno = 20);

上面的SQL語句的意義與前面的就完全不一樣了,其意義是找到比部門號爲20的員工的所有員工的工資都要高的員工,也就是比那個工資最高的員工的還要高的員工

總的來說some和any用法意義是一樣的,僅在詞法上有不同,都表示對子查詢結果集中“或”的比較關係,而all則是對子查詢結果集總每一個結果“與”的關係

****************************************************************************************************************************

這是在Oracle中比較容易被忽視的兩個條件函數,但這兩個函數其實對簡化Sql語句是非常重要的作用的。

  例如

scott@eddev> select ename, sal  from emp  where sal > any (1600, 2999);

ENAME             SAL
---------- ----------
JONES            2975
BLAKE            2850
CLARK            2450
SCOTT            3000
KING             5000
FORD             3000

6 rows selected.

實際上以上語句可以等於:

select ename, sal  from emp where sal > 1600 or sal > 2999;

所以Any是等於N個or語句。

又如

select ename from emp  where substr(ename,1,1) = any ('A', 'W', 'J');
等同於:

select ename from emp  where substr(ename,1,1) = 'A' or substr(ename,1,1) ='W' or substr(ename,1,1) ='J';
另外
scott@eddev> select ename, sal   from emp   where sal > all (1600, 2999);
ENAME             SAL
---------- ----------
SCOTT            3000
KING             5000
FORD             3000
實際上以上語句可以等於:
select ename, sal   from emp   where sal > 1600 and sal > 2999;

所以All是等於N個And語句。這是在Oracle中比較容易被忽視的兩個條件函數,但這兩個函數其實對簡化Sql語句是非常重要的作用的。

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