在oracle的子查詢中使用some,any和all
用some,any和all對子查詢中返回的多行結果進行處理。下面我們來簡單介一下這幾個關鍵詞的含義。
•Some在此表示滿足其中一個的意義,是用or串起來的比較從句。
•Any也表示滿足其中一個的意義,也是用or串起來的比較從句,區別是any一般用在非“=”的比較關係中,這也很好理解,英文中的否定句中使用any肯定句中使用sone,這一點是一樣的。
•All則表示滿足其其中所有的查詢結果的含義,使用and串起來的比較從句。
下面是一些例子[@more@]找出員工中,只要比部門號為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語句是非常重要的作用的。
例如
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語句。
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/7490392/viewspace-1052053/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 子查詢中all與any的區別
- ALL, ANY and SOME Comparison Conditions in SQLSQL
- Swift 5.7 中的 any 和 some (譯)Swift
- Oracle OCP(08):使用子查詢Oracle
- 15、Oracle中的高階子查詢Oracle
- oracle子查詢Oracle
- SQL查詢的:子查詢和多表查詢SQL
- 使用子查詢
- Oracle with重用子查詢Oracle
- oracle with 子查詢用法Oracle
- mysql求交集:UNION ALL合併查詢,inner join內連線查詢,IN/EXISTS子查詢MySql
- Transformation之Non-correlated(無關聯子查詢)=any的transform【五】ORM
- MySQL中使用or、in與union all在查詢命令下的效率對比MySql
- 關於mysql 子查詢中 使用 limitMySqlMIT
- 在Oracle中查詢儲存過程和函式Oracle儲存過程函式
- 在關聯子查詢中in與exists的區別
- MySQL聯結查詢和子查詢MySql
- Oracle OCP(14):使用子查詢檢索資料Oracle
- RAC:在子查詢使用gv$檢視,有時查詢不出資料
- 子查詢-表子查詢
- 【Django】關聯查詢set.all() 方法的使用Django
- Oracle查詢轉換(五)子查詢展開Oracle
- MySQL之連線查詢和子查詢MySql
- 區分關聯子查詢和非關聯子查詢
- exist-in和關聯子查詢-非關聯子查詢
- 教你使用SQLite 子查詢SQLite
- [MYSQL -14]使用子查詢MySql
- Oracle_Day2 子查詢Oracle
- 在Oracle中進行大小寫不敏感的查詢Oracle
- Elasticsearch中的Term查詢和全文查詢Elasticsearch
- MySQL全面瓦解11:子查詢和組合查詢MySql
- 子查詢包含where ..or在Corelated Subquery 中語句中問題
- 使用子查詢檢索資料
- 原創:oracle 子查詢介紹Oracle
- Oracle not exist子查詢全掃的優化Oracle優化
- oracle 精確查詢和模糊查詢Oracle
- 樹結構表遞迴查詢在ORACLE和MSSQL中的實現方法遞迴OracleSQL
- swift 中的 AnyObject 和 AnySwiftObject