Skip to main content

Pagination Query in Sql server

I was asked a question or a series of questions, "How would you do paging in a SQL? How would you do this with a lot of records, say, 10,000 or more?"

I thought about answers. To be more precise, I thought of more questions and this got me thinking, "This must be a common problem, every developer must have done or solved this. What about paging sizes and working with very large data sets? What about getting results from multiple tables?"

So, I decided to look into these questions and found the queries that works in different versions of sql server

Pagination in sql server 2000

declare @pageNumber int,@pageSize int
set @pageNumber=2
set @pageSize=10

SELECT * FROM
(
    SELECT TOP (@pageSize) * FROM
    (
        SELECT TOP (@pageNumber * @pageSize) *
        FROM Citymaster
        ORDER BY CityID ASC
    ) AS t1
    ORDER BY CityID DESC
) AS t2
ORDER BY CityID ASC

Pagination in sql server 2005

Option- 1

declare @pageNumber int,@pageSize int
set @pageNumber=2
set @pageSize=10

;WITH results AS (
    SELECT
        rowNo = ROW_NUMBER() OVER( ORDER BY Cityid ASC )
        , *
    FROM Citymaster
)
SELECT *
FROM results
WHERE rowNo between (@pageNumber-1)*@pageSize+1 and @pageNumber*@pageSize

Option- 2

declare @pageNumber int,@pageSize int
set @pageNumber=2
set @pageSize=10

SELECT *
FROM (SELECT ROW_NUMBER() OVER(ORDER BY Cityid) RowNr, * FROM Citymaster) t
WHERE RowNr BETWEEN ((@pageNumber-1)*@pageSize) AND (@pageNumber*@pageSize)


If you face any issue in implementing this code please comment here. We will help you.


Comments

  1. I run the script of "Pagination in sql server 2000", it comes an error message :

    Server: Msg 170, Level 15, State 1, Line 6
    Line 6: Incorrect syntax near '('.

    ReplyDelete
    Replies
    1. Can you post ur query here.. along with table details...

      Delete
    2. declare @pageNumber int, @pageSize int
      set @pageNumber = 2
      set @pageSize = 3

      SELECT TOP (@pageNumber) *
      FROM Top_5
      ORDER BY TM ASC

      ==================
      I use SQL Server 2000

      Table Top_5 :
      -------------------
      Dealer_ID (nvarchar 5)
      ...
      ...
      TM (int 4) ----> TM = This Month Sales

      Delete

Post a Comment

Popular posts from this blog

Sort Dictionary Based On Value In Asp.Net And C#.Net | Convert Dictionary into KeyValuePair or KeyValuePair into Dictionary.

In this tutorial i am going to explain about how to sort dictionary object based on value in asp.net and C#.Net or convert unsorted dictionary to sorted dictionary object in C#.Net and VB.Net or Convert Dictionary into KeyValuePair or KeyValuePair into Dictionary.

Geckofx Browser in Winform Application

Bored with IE browser in your winform application ? Want to do everything as you doing in your Firefox or Chrome Browser ? Play with automation ? Then here is your choice . Introduction:  GeckoFX is a Windows Forms control written in clean, commented C# that embeds the Mozilla Gecko browser control in any Windows Forms Application. It also contains a simple class model providing access to the HTML and CSS DOM . GeckoFX was originally created by Andrew Young for the fast-growing visual CSS editor, Stylizer . It is now released as open-source under the Mozilla Public License.  You can download it here :   Geckofx 22.0 And the supporting file Xulrunner here :   Xulrunner Files Hope you have downloaded above two files. Here our journey going to start. Create your winform application in visual studio and do the following: right click the toolbox -> Choose items -> Browse the "Geckofx-winforms.dll" and click "yes" for “Load it anyw...

Code To Convert rupees(numbers) into words using C#.Net

Introduction: In my previous article I have explained about how to validate emailid using javascript . In this article I am going to explain about code used to convert rupees(numbers) into words using C#.Net . Explanation: For explanation purpose I have a page. It has a textbox to input the numbers. And when you click on the convert to words button then it will convert the input numbers into words and shows it in the below label. Below is the C# code used to do this functionality. public static string NumbersToWords( int inputNumber) {     int inputNo = inputNumber;     if (inputNo == 0)         return "Zero" ;     int [] numbers = new int [4];     int first = 0;     int u, h, t;     System.Text. StringBuilder sb = new System.Text. StringBuilder ();     if (inputNo < 0)     { ...