SQLserver中的any和all運(yùn)算符的用法
一,SQL Server Any 運(yùn)算符
Any 是一個(gè)邏輯運(yùn)算符 ,它將值與子查詢返回的一組進(jìn)行比較。any運(yùn)算符必須要結(jié)合比較運(yùn)算符使用,
>,>=,<,<=,=,<>開頭,后面就是子查詢
where 比較者 >any(子查詢)
如果子查詢不返回如何行,則條件計(jì)算結(jié)果為false,就是返回空的意思,進(jìn)行不了比較。
如果子查詢不返回零行,下面說明了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)算符使用,>,>=,<,<=,=,<>開頭,后面就是子查詢
where 比較者 >all(子查詢)
注意:如果子查詢不返回任何行。則where子句中的條件始終未true,假設(shè)子查詢返回一行或多行,下表
說明名了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)文章希望大家以后多多支持腳本之家!
相關(guān)文章
數(shù)據(jù)庫(kù)設(shè)計(jì)三大范式簡(jiǎn)析
這篇文章主要介紹了數(shù)據(jù)庫(kù)設(shè)計(jì)三大范式簡(jiǎn)析,遵循范式是為了建立冗余較小、結(jié)構(gòu)合理的數(shù)據(jù)庫(kù),需要學(xué)習(xí)數(shù)據(jù)庫(kù)設(shè)計(jì)三大范式的朋友可以參考下2015-08-08sqlserver 數(shù)據(jù)庫(kù)壓縮與數(shù)據(jù)庫(kù)日志(ldf)壓縮方法分享
數(shù)據(jù)庫(kù)在使用中,冗余的數(shù)據(jù)不斷的增加(數(shù)據(jù)刪除也不會(huì)減?。?,導(dǎo)致數(shù)據(jù)庫(kù)不斷的增大!所以該給你的數(shù)據(jù)庫(kù)減減肥了2011-12-12SQL?Server修改數(shù)據(jù)的幾種語句詳解
在SQL中的基本操作就是增刪改查,查詢語句不會(huì)對(duì)數(shù)據(jù)庫(kù)中的數(shù)據(jù)進(jìn)行修改,下面這篇文章主要給大家介紹了關(guān)于SQL?Server修改數(shù)據(jù)的幾種語句,需要的朋友可以參考下2022-10-10SQL?server數(shù)據(jù)庫(kù)log日志過大占用內(nèi)存大的解決辦法
SQL Server日志文件過大,隨著時(shí)間的推移會(huì)占用很大的存儲(chǔ)空間,下面這篇文章主要給大家介紹了關(guān)于SQL?server數(shù)據(jù)庫(kù)log日志過大占用內(nèi)存大的解決辦法,文中通過圖文介紹的非常詳細(xì),需要的朋友可以參考下2024-05-05SQL學(xué)習(xí)筆記六 union聯(lián)合結(jié)果集使用
SQL學(xué)習(xí)筆記六 union聯(lián)合結(jié)果集使用,需要的朋友可以參考下。2011-08-08SQL語句練習(xí)實(shí)例之七 剔除不需要的記錄行
相信大家肯定經(jīng)常會(huì)把數(shù)據(jù)導(dǎo)入到數(shù)據(jù)庫(kù)中,但是可能會(huì)有些記錄行的所有列的數(shù)據(jù)是null,這為null的數(shù)據(jù)是我們不需要2011-10-10sqlserver查找括號(hào)()中字符串內(nèi)容的方法實(shí)現(xiàn)
本文主要介紹了sqlserver查找括號(hào)()中字符串內(nèi)容的方法實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-05-05