『壹』 sql 中some和all的區別
--All:對所有數據都滿足條件,整個條件才成立,例如:5大於所有返回的id
select *
from #A
where 5>All(select id from #A)
go
--Any:只要有含明一條數據滿足條悔兆件,整個談前告條件成立,例如:3大於1,2
select *
from #A
where 3>any(select id from #A)
『貳』 如何利用SQL Server 2012 關鍵字ANY,ALL,SOME
第一步,利返巧用資源管理器創建資料庫表t_amount_info,有三個欄位id、amount和price,如下圖所示:
第二步,向資料庫表t_amount_info里插入四條數據,如下圖所示:
第三步,再創建資料庫表t_anum_info,也包含三個欄位id、anum、aprice,如下圖所示:
第四步,向資料庫表t_anum_info插入五條數據,如下圖所示:
第五步,查詢t_anum_info表裡欄位aprice任一大於t_amount_info中的欄位price,利用漏差鍵ANY關鍵字實現,如下圖所示:
第六步,查詢t_anum_info表裡欄位aprice任一大於t_amount_info中的欄位price,利用SOME關鍵字實現,如下圖所示:
第七步,查詢t_anum_info表裡欄位aprice所有大於慶差t_amount_info中的欄位price,利用ALL關鍵字實現,如下圖所示:
『叄』 請教高手在sql里in,all,any,some的區別和具體應用范圍
給你些例子:
in 是 確定集合的
SELECT au_lname, state
FROM authors
WHERE state IN ('CA', 'IN', 'MD')
結果:
au_lname state
-------- ----
Yokomoto CA
DeFrance IN
Stringer CA
MacFeather CA
Karsen CA
Panteley MD
Hunter CA
all 是查詢還可以轎念是子查詢
如:
select name from edit
其中name前省略了all.
name前可以加ALL|DISTINCT
all是所有記錄.
distinct是不重復的。
帶【any】的嵌套查詢和【some】的嵌套查詢功能是一樣的。早期的SQL僅僅允許使用【any】,後來的版本為了和英語的【any】相區分,引入了【some】,同時還保留了【any】關鍵詞。
any:
select emp.empno,emp.ename,emp.job,emp.sal from scott.emp where sal >any(select sal from scott.emp where job='MANAGER');
帶any的查詢過程等價於兩步的執行過程。
(1)執行「select sal from scott.emp where job='MANAGER'」
select emp.empno,emp.ename,emp.job,emp.sal from scott.emp where sal >2975 or sal>2850 or sal>2450;
some:
select emp.empno,emp.ename,emp.job,emp.sal from scott.emp where sal =some(select sal from scott.emp where job='MANAGER'殲鄭);
帶氏帆頌some的嵌套查詢與any的步驟相同。
(1)子查詢,執行「select sal from scott.emp where job='MANAGER'」,其結果如圖4.22所示。
(2)父查詢執行下列語句。
―――――――――――――――――――――――――――――――――――――
select emp.empno,emp.ename,emp.job,emp.sal from scott.emp where sal =2975 or sal=2850 or sal=2450;
『肆』 請問大家在sql中all,any ,exists ,some四個關鍵字怎麼用
select * from table a
where a.col1 > all(select col1 from b )
意思 是 a表的 col1列,大於括弧裡面的 所有值
where a.col1>any (select col1 from b)
意思 是 a表的 col1列,只要大於 括弧裡面的 一個值
where exists (select col1 from b)
意思 是 只要存在 值 就成立。
some 就不懂了
『伍』 操作符的SQL里的操作符
相等:相等操作符在SQL語句里比較一個值與另一個值,等號(=)表示相等。在進行相等比較時,被比較的值必須完全匹配,否則就不會返回數據。如果在相等比較過程中兩個值相等,那麼這個比較的返回值就是true,否則就是false。這個布爾值(true或false)用於決定是否返回數據。
不相等:在SQL里表示不相等的操作符是<>(一個小於號和一個大於號)。如果兩個值不相等,條件就返回true,否則就返回false。另一種表示不相等的方式是!=,而且很多主要的SQL實現採用這種方式。
小於:<
大於:>
比較操作符的組合:等號可以與小於號和大於號聯合使用。 用戶對SQL關鍵字而不是符號進行比較。
is null:這個操作符用於與null值進行比較。
between:操作符between用於尋找位於一個給定最大值和最小值之間的值,這個最大值和最小值是包含在內的。between是包含邊界值的,所以查詢結果里會包含指定的最大值和最小值。
in:操作符in用於把一個值與一個指定列表進行比較,當被比較的值至少與列表中一個值相匹配時,它會返回true。使用操作符in可以得到操作符or一樣的結果,但它的速度更快。
like:操作符like利用通配符把一個值與類似的值進行比較,通配符有兩個:百分號(%);下劃線(_)。百分號代表零個、一個或多個字元;下劃線( _ )代表一個數字或字元。
exists:這個操作符用於搜索指定表裡是否存在滿足特定條件的記錄。
all:操作符all用於把一個值與另一個集合里全部值進行比較。
any/some:操作符any用於把一個值與另一個列表裡任意值進行比較。some是any的別名,它們可以互換使用。 如果想在SQL語句里利用多個條件來縮小數據范圍,我們就需要組合多個條件。這正是連接操作符的功能。
and:操作符and讓我們可以在一條SQL語句的where子句里使用多個條件。在使用and時,無論SQL語句是事務操作還是查詢,所有由and連接的條件都必須為true,SQL語句才會實際執行。
or:操作符or可以在SQL語句的where子句中連接多個條件,這時無論SQL語句是事務操作還是查詢,只要or連接的條件里有至少一個是true,SQl語句就會執行。
注意:比較操作符和邏輯操作符都可以單獨或彼此復合使用。
提示:當SQL語句里包含多個條件和操作符時,利用圓括弧把語句按照邏輯關系進行劃分可以提高語句的可讀性。當然,不恰當地使用圓括弧也會影響輸出結果。 操作符not可以顛倒邏輯操作符的含義,它可以與其他操作符構成以下幾種形式:
not equal:不相等
not between:操作符between的求反
not in:操作符in的求反
not like:操作符like的求反
is not null:操作符is null的求反
not exists:操作符exists的求反
not unique:操作符distinct的求反 加法(+)
減法(-)
乘法(*)
除法(/)
算術操作符可以彼此組合使用,並且遵循基本算數運算中的優先順序:首先執行乘法和除法,然後是加法和減法。用戶控制算術運算次序的唯一方式是使用圓括弧,圓括弧里包含的表達式會被當作一個整體進行優先求值。
『陸』 如何利用SQL Server 2012 關鍵字ANY,ALL,SOME
給你些例子:
in 是 確定集合的
SELECT au_lname, state
FROM authors
WHERE state IN ('CA', 'IN', 'MD')
結果:
au_lname state
-------- ----
Yokomoto CA
DeFrance IN
Stringer CA
MacFeather CA
Karsen CA
Panteley MD
Hunter CA
all 是查詢還可以是子查詢
如:
select name from edit
其中name前省略了all.
name前可以加ALL|DISTINCT
all是所有記錄.
distinct是不重復的。
帶【any】的嵌套查詢和【some】的嵌套查詢功能是一樣的。早期的SQL僅僅允許使用【any】,後來的版本為了和英語的【any】相區分,引入了【some】,同時還保留了【any】關鍵詞。
any:
select emp.empno,emp.ename,emp.job,emp.sal from scott.emp where sal >any(select sal from scott.emp where job='MANAGER');
帶any的查詢過程等價於兩步的執行過程。
(1)執行「select sal from scott.emp where job='MANAGER'」
select emp.empno,emp.ename,emp.job,emp.sal from scott.emp where sal >2975 or sal>2850 or sal>2450;
some:
select emp.empno,emp.ename,emp.job,emp.sal from scott.emp where sal =some(select sal from scott.emp where job='MANAGER');
帶some的嵌套查詢與any的步驟相同。
(1)子查詢,執行「select sal from scott.emp where job='MANAGER'」,其結果如圖4.22所示。
(2)父查詢執行下列語句。
―――――――――――――――――――――――――――――――――――――
select emp.empno,emp.ename,emp.job,emp.sal from scott.emp where sal =2975 or sal=2850 or sal=2450;