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