好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > SqlServer 2005 T-SQL Query 學習筆記(3)

SqlServer 2005 T-SQL Query 學習筆記(3)

熱門標簽:中國地圖標注省份用什么符號 電話機器人錄音師薪資 智能電銷機器人教育 高德地圖標注電話怎么沒了 北京智能外呼系統供應商家 孝感銷售電銷機器人廠家 江西穩定外呼系統供應商 無錫梁溪公司怎樣申請400電話 奧維地圖標注字體大小修改

AD HOC PAGING

就是指用頁面的序號和頁面的大小請求一個單獨的頁面。下面是例子。

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;

 
說明:在上個例子中,其實SQL只審視了10行(2*5),也就是說,查看N頁的話,SQL只查到N的頁的數據,N頁后面的數據一概不查看。
 
另外,每當移動一頁,都會把這頁放進緩存里,因此每次查詢,就是邏輯查詢(緩存)+物理查詢的過程。物理查詢只需要查詢新請求的頁即可,其他全部在緩存里執行,這樣大大加快了查詢速度。
 
 

MULTIPAGE ACCESS:

如果結果集不是很大,而且分了多個請求頁面,請求也不向前移動,那么這是一個好的方案:首先在一個表里使用ROW_NUMBER具體化所有的頁,然后創建一個群集索引。下面是例子。

 

首先創建按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個函數和ROW_NUMBER的區別是:ROW_NUMBER在ORDER BY的條件里有重復行存在的話,是把這些重復行也按INDEX排列的,但是RANK和DENSE RANK總是確定的,即只要是ORDER BY重復的行,他們是統一INDEX的。

 

RANK和DENSE_RANK的區別是,RANK是如果上級的INDEX和下級的INDEX有可能不是+1關系,是按下級真正處于列里的位置進行INDEX,而DENSE_RANK是按照跟上級的INDEX+1的關系進行的編碼。

 

比如:

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函數一樣,只不過它可以傳入一個參數,用來決定最大的INDEX是多少:它會按行數進行除法,然后平均分配行數進行INDEX的標示。

比如,如果有11列,那么首先11/3=3,3列一組作為一個INDEX,然后,11%3=2,這2列會分別加在前面的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;
您可能感興趣的文章:
  • SQLServer用t-sql命令批量刪除數據庫中指定表(游標循環刪除)
  • 如何在SQL Server 2008下輕松調試T-SQL語句和存儲過程
  • SQL Server中的T-SQL的基本對象
  • SqlServer 2005 T-SQL Query 學習筆記(4)
  • SqlServer 2005 T-SQL Query 學習筆記(2)
  • SqlServer 2005 T-SQL Query 學習筆記(1)
  • SQLServer 2008 新增T-SQL 簡寫語法
  • SQL Server 數據庫管理常用的SQL和T-SQL語句
  • SQL Server 數據庫管理常用的SQL和T-SQL語句
  • SQL Server 數據庫管理常用的SQL和T-SQL語句
  • T-sql語句修改SQL Server數據庫邏輯名、數據庫名、物理名的方法

標簽:荊州 海北 通化 臨滄 泰州 那曲 阜陽 齊齊哈爾

巨人網絡通訊聲明:本文標題《SqlServer 2005 T-SQL Query 學習筆記(3)》,本文關鍵詞  SqlServer,2005,T-SQL,Query,學習,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《SqlServer 2005 T-SQL Query 學習筆記(3)》相關的同類信息!
  • 本頁收集關于SqlServer 2005 T-SQL Query 學習筆記(3)的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 成本人片在线观看三三网站| 久草免费福利视频| 97福利影院| 毛耸耸亚洲熟妇性XXXX交潮喷| 脱了美女内裤猛烈进入gif视| 午夜激情视频在线观看| 美女视频黄a视频在线观看免费| 秋霞A片一级毛片日本| 韩国三级理在线视频观看| 黄色软件快播| 日韩理论在线| 日本少妇极品熟妇人妻| 我的妻子的姐姐3| 色屁屁www一区二区三区| 曰本三级香港三级人妇99视频| 精品孕妇一区二区三区| 亚洲一级大片| 揉?啊?嗯~出水了| 第一次的人妻1~5集动漫| 久久人人爽人人爽大片aw| 军人脱男生内裤摸j的经历| 韩国免费三?片| 大ji巴想cao死你男男| 久久久人成影片免费观看| 乖?好舒服?把腿张开出轨| 爱瑟瑟精品视频在线播放| 白丝被弄羞涩娇喘动态图| 免费无遮挡??视频网站动漫闺蜜| 武侠与子乱系列小说| 关晓彤一级做a爰片性色毛片| 禁欲佛子高H肉辣文| 男男互攻互受H啪肉np文| 久久久久无码国产精品不卡| 99久久夜色精品国产亚洲软件| 欧美精品色视频| 久久精品视频1| 男男纯肉高被??爽到翻白眼| 四川性BBB搡BBB爽爽爽小说| 午夜精品久久久久久影视riav| 孕妇japanese孕交| 国产一区二区三区电影|