SQLserver中的any和all運算符的用法
目錄
- 一,SQL Server Any 運算符
- 二,SQL Server All 運算符
- 總結:any和all的區別
一,SQL Server Any 運算符
Any 是一個邏輯運算符 ,它將值與子查詢返回的一組進行比較。any運算符必須要結合比較運算符使用,
>,>=,<,<=,=,<>開頭,后面就是子查詢
where 比較者 >any(子查詢)
如果子查詢不返回如何行,則條件計算結果為false,就是返回空的意思,進行不了比較。
如果子查詢不返回零行,下面說明了any運算符與每個比較運算符一起使用的含義:
條件
含義
c = ANY (…)
c列中的值必須與集合中的一個或多個值匹配,以評估為true。
c != ANY (…)
c列中的值不能與集合中的一個或多個值匹配以評估為true。
c > ANY (…)
c列中的值必須大于要評估為true的集合中的最小值。
c < ANY (…)
c列中的值必須小于要評估為true的集合中的最大值。
c >= ANY (…)
c列中的值必須大于或等于要評估為true的集合中的最小值。
c <= ANY (…)
c列中的值必須小于或等于要評估為true的集合中的最大值。
示例:--29、查詢選修編號為“3-105“課程且成績至少高于選修編號為“3-245”的同學的Cno、Sno和Degree,并按Degree從高到低次序排序。
二,SQL Server All 運算符
All是一個邏輯運算符,它將單個值與子查詢返回的單例值進行比較。
all運算符必須要結合比較運算符使用,>,>=,<,<=,=,<>開頭,后面就是子查詢
where 比較者 >all(子查詢)
注意:如果子查詢不返回任何行。則where子句中的條件始終未true,假設子查詢返回一行或多行,下表
說明名了ALL運算符的含義:
條件
含義
c > ALL(…)
c列中的值必須大于要評估為true的集合中的最大值。
c >= ALL(…)
c列中的值必須大于或等于要評估為true的集合中的最大值。
c < ALL(…)
c列中的值必須小于要評估為true的集合中的最小值。
c <= ALL(…)
c列中的值必須小于或等于要評估為true的集合中的最小值。
c <> ALL(…)
c列中的值不得等于要評估為true的集合中的任何值。
c = ALL(…)
c列中的值必須等于要評估為true的集合中的任何值。
示例:--30、查詢選修編號為“3-105”課程且成績高于選修編號為“3-245”課程的同學的Cno、Sno,Degree.
總結:any和all的區別
他們又被稱為多行子查詢,一般是用于查詢比較返回多行的數據,這兩個運算符都是用于子查詢,
any是任意,all是任何。這個任意和任何怎么理解呢?
好比如上面any和all的兩個例子,都是大于號,any要大于子查詢里面的最小一個,因為任一條數據滿足外層查詢都會被返回。all要大于里面最大的一個,任何就是包括集合里所有的數據。這就是我所理解的any和all。
到此這篇關于SQLserver中的any和all運算符的用法的文章就介紹到這了,更多相關SQLserver any和all運算符內容請搜索以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持!
