程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> MYSQL數據庫 >> MySQL綜合教程 >> SQL server 2005的簡單分頁程序

SQL server 2005的簡單分頁程序

編輯:MySQL綜合教程

SQL server 2005的簡單分頁程序


   SQL Server 2005增加了不少新特性,其中NTILE和ROW_NUMER使得我們不再為SQL如何靈活方便的分頁傷腦筋了(不必再羨慕Oracle等數據庫了)。

  下面就是一個很簡單的分頁查詢語句:

  DECLARE @rows_per_page AS INTEGER

  DECLARE @current_page AS INTEGER

  DECLARE @total_pages AS INTEGER

  -- 設置每頁的行數

  SET @rows_per_page = 20

  -- 設置要顯示的頁號(從1開始)

  SET @current_page = 2

  -- 計算總頁數

  SELECT @total_pages = COUNT(*) / @rows_per_page

  FROM testtable;

  -- 列出指定頁的內容

  WITH t AS

  (

  SELECT NTILE(@total_pages) OVER(ORDER BY id) AS page_number, *

  FROM testtable

  )

  SELECT * from t

  WHERE page_number = @current_page

  程序簡單到可以不用說明的程度。

  我們可以利用上述簡單的語句,變化排序條件和查詢表,就可以做出一個很通用的分頁查詢的存儲過程或查詢語句了。

  同樣的,使用ROW_NUMBER也可以做到分頁查詢:

  DECLARE @rows_per_page AS INTEGER

  DECLARE @current_page AS INTEGER

  DECLARE @start_row_num AS INTEGER

  -- 設置每頁的行數

  SET @rows_per_page = 20

  -- 設置要顯示的頁號(從1開始)

  SET @current_page = 2

  -- 設置開始行號

  SET @start_row_num = (@current_page - 1) * @rows_per_page

  WITH t AS

  (

  SELECT ROW_NUMBER() OVER(ORDER BY id) AS row_number, *

  FROM testtable

  )

  SELECT * from t

  WHERE row_number BETWEEN @start_row_num AND @start_row_num + @rows_per_page  似乎更簡單的樣子。

  至於哪種效率更高,這需要大家實際測試了。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved