SqlServer 2005 T-SQL Query 學(xué)習(xí)筆記(3)
AD HOC PAGING:
就是指用頁(yè)面的序號(hào)和頁(yè)面的大小請(qǐng)求一個(gè)單獨(dú)的頁(yè)面。下面是例子。
DECLARE @pagesize AS INT, @pagenum AS INT; SET @pagesize = 5; SET @pagenum = 2; WITH SalesCTE AS ( SELECT ROW_NUMBER() OVER(ORDER BY qty, empid) AS rownum, empid, mgrid, qty FROM dbo.Sales ) SELECT rownum, empid, mgrid, qty FROM SalesCTE WHERE rownum > @pagesize * (@pagenum-1) AND rownum <= @pagesize * @pagenum ORDER BY rownum;
說(shuō)明:在上個(gè)例子中,其實(shí)SQL只審視了10行(2*5),也就是說(shuō),查看N頁(yè)的話,SQL只查到N的頁(yè)的數(shù)據(jù),N頁(yè)后面的數(shù)據(jù)一概不查看。
另外,每當(dāng)移動(dòng)一頁(yè),都會(huì)把這頁(yè)放進(jìn)緩存里,因此每次查詢,就是邏輯查詢(緩存)+物理查詢的過(guò)程。物理查詢只需要查詢新請(qǐng)求的頁(yè)即可,其他全部在緩存里執(zhí)行,這樣大大加快了查詢速度。
MULTIPAGE ACCESS:
如果結(jié)果集不是很大,而且分了多個(gè)請(qǐng)求頁(yè)面,請(qǐng)求也不向前移動(dòng),那么這是一個(gè)好的方案:首先在一個(gè)表里使用ROW_NUMBER具體化所有的頁(yè),然后創(chuàng)建一個(gè)群集索引。下面是例子。
首先創(chuàng)建按ROW_NUMBER把列編好,
SELECT ROW_NUMBER() OVER(ORDER BY qty, empid) AS rownum, empid, mgrid, qty INTO #SalesRN FROM dbo.Sales; CREATE UNIQUE CLUSTERED INDEX idx_rn ON #SalesRN(rownum);
然后直接按ROWNUM查詢,
DECLARE @pagesize AS INT, @pagenum AS INT; SET @pagesize = 5; SET @pagenum = 2; SELECT rownum, empid, mgrid, qty FROM #SalesRN WHERE rownum BETWEEN @pagesize * (@pagenum-1) + 1 AND @pagesize * @pagenum ORDER BY rownum;
RANK & DENSE RANK
這2個(gè)函數(shù)和ROW_NUMBER的區(qū)別是:ROW_NUMBER在ORDER BY的條件里有重復(fù)行存在的話,是把這些重復(fù)行也按INDEX排列的,但是RANK和DENSE RANK總是確定的,即只要是ORDER BY重復(fù)的行,他們是統(tǒng)一INDEX的。
RANK和DENSE_RANK的區(qū)別是,RANK是如果上級(jí)的INDEX和下級(jí)的INDEX有可能不是+1關(guān)系,是按下級(jí)真正處于列里的位置進(jìn)行INDEX,而DENSE_RANK是按照跟上級(jí)的INDEX+1的關(guān)系進(jìn)行的編碼。
比如:
SELECT empid, qty, RANK() OVER(ORDER BY qty) AS rnk, DENSE_RANK() OVER(ORDER BY qty) AS drnk FROM dbo.Sales ORDER BY qty;
NTILE
NTILE的用法和其他的RANK函數(shù)一樣,只不過(guò)它可以傳入一個(gè)參數(shù),用來(lái)決定最大的INDEX是多少:它會(huì)按行數(shù)進(jìn)行除法,然后平均分配行數(shù)進(jìn)行INDEX的標(biāo)示。
比如,如果有11列,那么首先11/3=3,3列一組作為一個(gè)INDEX,然后,11%3=2,這2列會(huì)分別加在前面的2組上。
比如,
SELECT empid, qty, CASE NTILE(3) OVER(ORDER BY qty, empid) WHEN 1 THEN 'low' WHEN 2 THEN 'medium' WHEN 3 THEN 'high' END AS lvl FROM dbo.Sales ORDER BY qty, empid;
相關(guān)文章
SQL Server 2005中的外聯(lián)結(jié)用法
這篇文章主要介紹了SQL Server 2005中的外聯(lián)結(jié)用法 ,需要的朋友可以參考下2014-08-08解決SQL2005備份數(shù)據(jù)庫(kù).dat或bak還原時(shí)的結(jié)構(gòu)錯(cuò)誤的解決方法
已備份數(shù)據(jù)庫(kù)的磁盤(pán)上結(jié)構(gòu)版本為611. 服務(wù)器支持版本539, 無(wú)法還原或升級(jí)此數(shù)據(jù)庫(kù),RESTORE DATABASE 操作異常終止。2011-02-02SQL Server 2005 定時(shí)執(zhí)行SQL語(yǔ)句的方法
這篇文章主要介紹了SQL Server 2005 定時(shí)執(zhí)行SQL語(yǔ)句的方法,需要的朋友可以參考下2015-07-07SQL Server 中 RAISERROR 的用法詳細(xì)介紹
這篇文章主要介紹了SQL Server 中 RAISERROR 的用法詳細(xì)介紹的相關(guān)資料,需要的朋友可以參考下2016-11-11Sql server 2005安裝時(shí)ASP.Net版本注冊(cè)要求警告的解決方法
這篇文章主要介紹了Sql server 2005安裝時(shí)ASP.Net版本注冊(cè)要求警告的解決方法,需要的朋友可以參考下2015-01-01在SQLServer 2005中編寫(xiě)存儲(chǔ)過(guò)程
在SQL Server 2000中,實(shí)際上只有一種創(chuàng)建存儲(chǔ)過(guò)程的方法:即T-SQL語(yǔ)句。之前的每個(gè)SQL Server版本都采用這個(gè)程序。2009-07-07SQL2005 ROW_NUMER實(shí)現(xiàn)分頁(yè)的兩種常用方式
SQL2005利用ROW_NUMER實(shí)現(xiàn)分頁(yè)的兩種常用方式2009-07-07SQL2005 學(xué)習(xí)筆記 公用表表達(dá)式(CTE)
公用表表達(dá)式是Sql Server2005新增加的一個(gè)非常好用的功能。2009-07-07