SQL Server子查詢的深入理解
當(dāng)由where子句指定的搜索條件指向另一張表時(shí),就需要使用子查詢或嵌套查詢。
1 子查詢
子查詢是一個(gè)嵌套在select、insert、update或delete語句或其他子查詢中的查詢。任何允許使用表達(dá)式的地方都可以使用子查詢。
1.1語法規(guī)則:
子查詢的select查詢總使用圓括號(hào)括起來不能包括compute或for browse子句如果同時(shí)指定top子句,則可能只包括order by子句子查詢最多嵌套32層,個(gè)別查詢可能會(huì)不支持32層嵌套任何可以使用表達(dá)式的地方都可以使用子查詢,主要它返回的是單個(gè)值如果某個(gè)表只出現(xiàn)在子查詢中而不出現(xiàn)在外部查詢中,那么該表中的列就無法包含在輸出中
1.2 語法格式:
where 查詢表達(dá)式 [not] in(子查詢)where 查詢表達(dá)式 比較運(yùn)算符 [any|all] (子查詢)where [not] exists (子查詢)
2 嵌套查詢
嵌套查詢是指將一個(gè)查詢塊嵌套在另一個(gè)查詢塊的where子句或having短語的條件中的查詢。
嵌套查詢中上層的查詢塊稱為外側(cè)查詢或父查詢,下層查詢塊稱為內(nèi)層查詢或子查詢。SQL語言允許多層嵌套,但是在子查詢中不允許出現(xiàn)order by子句,order by子句只能用在最外層的查詢中。
嵌套查詢的處理方法是:先處理最內(nèi)側(cè)的子查詢,然后一層一層地向上處理,直到最外層的查詢塊。
2.1 簡(jiǎn)單的嵌套查詢
子查詢的運(yùn)算符含有=、<>、<、>、<=、>=
三個(gè)查詢:
第一個(gè):查詢年紀(jì)>25的老師所教的學(xué)生
第二個(gè):查詢年紀(jì)>25的老師
第三個(gè):驗(yàn)證查詢到的學(xué)生信息

對(duì)比:當(dāng)子查詢中的分那會(huì)的結(jié)果不是一個(gè)時(shí),父查詢無法正常工作

2.2 帶IN的嵌套查詢
當(dāng)子查詢返回一系列值時(shí),適合帶IN的嵌套查詢。

2.3 NOT IN

2.4 SOME

2.5 ANY

2.6 ALL

2.7 EXIST

總結(jié)
到此這篇關(guān)于SQL Server子查詢的文章就介紹到這了,更多相關(guān)SQL Server子查詢內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
sqlldr裝載數(shù)據(jù)實(shí)現(xiàn)代碼
本文將詳細(xì)介紹如何用sqlldr裝載數(shù),需要了解更多的朋友可以參考下2012-12-12
一個(gè)簡(jiǎn)單的SQL 行列轉(zhuǎn)換語句
在數(shù)據(jù)庫開發(fā)中經(jīng)常會(huì)遇到行列轉(zhuǎn)換的問題,比如下面的問題,部門,員工和員工類型三張表,我們要統(tǒng)計(jì)類似這樣的列表2009-08-08
揭秘SQL Server 2014有哪些新特性(4)-原生備份加密
SQL Server原聲備份加密對(duì)數(shù)據(jù)安全提供了非常好的解決方案。使用原生備份加密基本不會(huì)增加備份文件大小,并且打破了使用透明數(shù)據(jù)加密后幾乎沒有壓縮率的窘境。2014-08-08
Java 實(shí)現(xiàn)連接sql server 2000
JDBC技術(shù)事實(shí)上是一種能通過JAVA語言訪問任何結(jié)構(gòu)化數(shù)據(jù)庫的應(yīng)用程序接口(API)(Sun這樣說的,我也不知道是不是真的),而且現(xiàn)在的JDBC 3.0據(jù)Sun說也能訪問Execel等電子表格程序!2009-06-06
實(shí)現(xiàn)SQL分頁的存儲(chǔ)過程代碼
本文主要介紹了分頁的存儲(chǔ)過程所實(shí)現(xiàn)代碼,使用存儲(chǔ)過程可以提高效率與節(jié)約時(shí)間,需要的朋友可以參考下2015-08-08

