用some,any和all對子查詢中返回的多行結(jié)果進行處理。下面我們來簡單介一下這幾個關(guān)鍵詞的含義。
-
•Some在此表示滿足其中一個的意義,是用or串起來的比較從句。
•Any也表示滿足其中一個的意義,也是用or串起來的比較從句,區(qū)別是any一般用在非“=”的比較關(guān)系中,這也很好理解,英文中的否定句中使用any肯定句中使用sone,這一點是一樣的。
•All則表示滿足其其中所有的查詢結(jié)果的含義,使用and串起來的比較從句。
推薦閱讀:Oracle函數(shù)取得姓名對應(yīng)的拼音 http://www.linuxidc.com/Linux/2011-05/35798.htm
下面是一些例子
找出員工中,只要比部門號為10的員工中的任何一個員工的工資高的員工的姓名個工資。也就是說只要比部門號為10的員工中的那個工資最少的員工的工資高就滿足條件。
select ename,sal
From emp
Where sal > any(select sal from emp where deptno = 10);
這里推薦用any,如果你非要用some也是沒有任何問題的,結(jié)果是一樣的,只是一般來講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部門員工的任何一個人工資相同的那些員工。雖然沒有找到。
最后一個關(guān)鍵字all的用法也很簡單就是要與子查詢的每一結(jié)果都要匹配。
select ename,sal
From emp
Where sal > all(select sal from emp where deptno = 20);
上面的SQL語句的意義與前面的就完全不一樣了,其意義是找到比部門號為20的員工的所有員工的工資都要高的員工,也就是比那個工資最高的員工的還要高的員工總的來說some和any用法意義是一樣的,僅在詞法上有不同,都表示對子查詢結(jié)果集中“或”的比較關(guān)系,而all則是對子查詢結(jié)果集總每一個結(jié)果“與”的關(guān)系
舉幾個例子來說明ALL和ANY的用法
1. SELECT * FROM TABLEA WHERE FLD > ALL(SELECT FLD FROM TABLEA)
這相當于
SELECT * FROM TABLEA WHERE FLD > (SELECT MAX(FLD) FROM TABLEA)
2. SELECT * FROM TABLEA WHERE FLD < ANY(SELECT FLD FROM TABLEA)
這相當于
SELECT * FROM TABLEA WHERE FLD < (SELECT MIN(FLD) FROM TABLEA)
3. SELECT * FROM TABLEA WHERE FLD = ANY(SELECT FLD FROM TABLEA)
這相當于
SELECT * FROM TABLEA WHERE FLD IN (SELECT FLD FROM TABLEA) 本文出自:億恩科技【mszdt.com】
服務(wù)器租用/服務(wù)器托管中國五強!虛擬主機域名注冊頂級提供商!15年品質(zhì)保障!--億恩科技[ENKJ.COM]
|