sql集合運(yùn)算符使用方法
(1)IN運(yùn)算符:它可以用來(lái)匹配一個(gè)固定集合中的某一項(xiàng)。比如說(shuō)一個(gè)集合里面的年份有(2001,2003,2005),那么就可以有:
SELECT * FROM T_Book
WHERE FYearPublished IN(2001,2003,2005)
IN運(yùn)算符,除了支持從固定的集合里面去匹配,當(dāng)然也支持動(dòng)態(tài)的集合方式去匹配。比如如下方式:
SELECT * FROM T_Reader
WHERE FYearOfJoin IN
(
select FYearPublished FROM T_Book
)
(2)ANY和SOME集合運(yùn)算符:在SQL SERVER里面,ANY和SOME是同義詞,二者的用法和功能一樣(一樣還搞兩個(gè))。相比于IN運(yùn)算符,ANY和SOME需要與其它的比較符(大于(>)、等于(=)、小于(<)、大于等于(>=)、小于等)共同使用,而且比較符需要在它們的前面。
SELECT * FROM T_Reader
WHERE FYearOfJoin =ANY
(
select FYearPublished FROM T_Book
)
注意:和IN 運(yùn)算符不同,ANY 和SOME運(yùn)算符不能與固定的集合相匹配,比如下面的SQL 語(yǔ)句是錯(cuò)誤的:
SELECT * FROM T_Book
WHERE FYearPublished<ANY(2001,2003,2005)
(3)ALL集合運(yùn)算符:在SQL SERVER里面,ALL運(yùn)算符也需要與其它的比較符(大于(>)、等于(=)、小于(<)、大于等于(>=)、小于等)共同使用,而且比較符需要在它們的前面。
SELECT * FROM T_Book
WHERE FYearPublished<ALL
(
SELECT FYearOfJoin FROM T_Reader
)
注意:
I、與ANY和SOME 運(yùn)算符相同,ALL 運(yùn)算符同樣不能與固定的集合相匹配,比如下面的SQL 語(yǔ)句是錯(cuò)誤的:
SELECT * FROM T_Book
WHERE FYearPublished<ALL(2001,2003,2005)
II、關(guān)于使用ALL運(yùn)算符,還有一項(xiàng)需要注意,那就是這個(gè)ALL子查詢(xún)結(jié)果為空時(shí),匹配的結(jié)果并不是以空的方式來(lái)處理,而是相當(dāng)于全部匹配成功。所以在使用ALL運(yùn)算符的時(shí)候,這一個(gè)問(wèn)題很容易在系統(tǒng)中造成BUG,因此使用時(shí)必須注意。比如:
SELECT * FROM T_Book
WHERE FYearPublished<ALL
(
SELECT FYearOfJoin FROM T_Reader
WHERE FProvince = 'JiangSu'
)
如果ALL子查詢(xún)的結(jié)果為空時(shí),則將會(huì)取SELECT FYearOfJoin FROM T_Reader的全部結(jié)果來(lái)作為成功匹配的結(jié)果。
(4)EXISTS集合運(yùn)算符:和IN、ANY、SOME、ALL等運(yùn)算符不同,EXISTS運(yùn)算符是單目運(yùn)算符,它不與列匹配,因此它也不要求待匹配的集合是單列的。EXISTS運(yùn)算符用來(lái)檢查每一行是否匹配子查詢(xún),可以認(rèn)為EXISTS就是用來(lái)測(cè)試子查詢(xún)的結(jié)果是否為空,如果結(jié)果集為空則匹配結(jié)果為false,否則匹配結(jié)果為true。
SELECT * FROM T_Category
WHERE EXISTS
(
SELECT * FROM T_Book
WHERE T_Book. FCategoryId = T_Category.FId
AND T_Book. FYearPublished<1950
)
在EXISTS后的子查詢(xún)中,SQL對(duì)T_Category表中的每一行數(shù)據(jù)到子查詢(xún)中進(jìn)行匹配,測(cè)試T_Book 表中是否存在FCategoryId 字段值等于當(dāng)前類(lèi)別主鍵值且出版年份在1950 年之前的書(shū)籍。
相關(guān)文章
針對(duì)SQL 2000 的分頁(yè)存儲(chǔ)過(guò)程代碼分享
針對(duì)SQL 2000 的分頁(yè)存儲(chǔ)過(guò)程,有詳細(xì)參數(shù)說(shuō)明2011-07-07SQL學(xué)習(xí)筆記八 索引,表連接,子查詢(xún),ROW_NUMBER
SQL學(xué)習(xí)筆記八 索引,表連接,子查詢(xún),ROW_NUMBER,學(xué)習(xí)sqlserver的朋友可以看下。2011-08-08SQL Server 獲取服務(wù)器時(shí)間的sql語(yǔ)句
這篇文章主要介紹了SQL Server 獲取服務(wù)器時(shí)間的sql語(yǔ)句,需要的朋友可以參考下2016-07-07sql語(yǔ)句之?dāng)?shù)據(jù)操作介紹
表中數(shù)據(jù)的變化牽一發(fā)而動(dòng)全身,會(huì)同時(shí)導(dǎo)致到索引中數(shù)據(jù)的變化。因此如果查詢(xún)語(yǔ)句不需要索引,就應(yīng)該刪除無(wú)用的索引以提高效率。2013-03-03INSERT INTO SELECT語(yǔ)句與SELECT INTO FROM語(yǔ)句的一些區(qū)別
INSERT INTO SELECT語(yǔ)句與SELECT INTO FROM語(yǔ)句的一些區(qū)別介紹,需要的朋友可以參考下面的說(shuō)明與條件2012-05-05