Click here to Skip to main content
15,884,629 members
Articles / Desktop Programming / Windows Forms

DataGrid Paging Using DataReader - C# Windows Forms

Rate me:
Please Sign up or sign in to vote.
3.20/5 (9 votes)
9 Nov 2006CPOL 79.2K   1.5K   41   2
DataGrid paging using DataReader.

Sample Image - DataGridPaging_DataReader.gif

Introduction

This is an example of Windows Forms DataGrid paging using C#. I have used a Microsoft SQL Server 2000 database in the demo.

Using the code

Create a table:

SQL
CREATE TABLE tblEmp (E_ID int PRIMARY KEY, E_Name varchar(60), 
                     E_Salary money, E_DOJ datetime)
GO

Public variables:

C#
// Protected Connection.
protected SqlConnection mcnSample;

// Page
private int mintTotalRecords = 0;
private int mintPageSize = 0;
private int mintPageCount = 0;
private int mintCurrentPage = 1;

// Connection String
protected const string CONNECTION_STRING = 
          "Server=localhost;UID=sa;PWD=;Database=Sample";

The fillGrid() method:

C#
private void fillGrid()
{
    // For Page view.
    this.mintPageSize = int.Parse(this.tbPageSize.Text);
    this.mintTotalRecords = getCount();
    this.mintPageCount = this.mintTotalRecords / this.mintPageSize;
    
    // Adjust page count if the last page contains partial page.
    if (this.mintTotalRecords % this.mintPageSize > 0)
        this.mintPageCount++;

    this.mintCurrentPage = 0;

    loadPage();
}

The getCount() method: this method gets the record count much faster than the SELECT COUNT(*) statement does.

C#
private int getCount()
{
    // This select statement is very fast compare to SELECT COUNT(*)
    string strSql = "SELECT Rows FROM SYSINDEXES WHERE " + 
                    "Id = OBJECT_ID('tblEmp') AND IndId < 2";
    int intCount = 0;

    SqlCommand cmd = this.mcnSample.CreateCommand();
    cmd.CommandText = strSql;

    intCount = (int) cmd.ExecuteScalar();
    cmd.Dispose();

    return intCount;
}

The loadPage() method:

C#
private void loadPage()
{
    string strSql = "";
    int intSkip = 0, i = 0;
    SqlDataReader dr;
    DataSet ds;
    DataTable dt;

    intSkip = (this.mintCurrentPage * this.mintPageSize);

    strSql = "SELECT * FROM tblEmp";

    SqlCommand cmd = this.mcnSample.CreateCommand();
    cmd.CommandText = strSql;

    dr = cmd.ExecuteReader(); 
    ds = new DataSet();

    dt = ds.Tables.Add("tblEmp");

    // Add the table columns.
    for (i = 0; i < dr.FieldCount; i++) 
        dt.Columns.Add(dr.GetName(i), dr.GetFieldType(i)); 

    int intIdx = 0;
    while (dr.Read())
    {
        if (intIdx >= intSkip)
        {
            DataRow r = dt.NewRow();

            // Assign DataReader values to DataRow.
            for (i = 0; i < dr.FieldCount; i++)
                r[i] = dr[i];

            dt.Rows.Add(r);
        }

        if ((intIdx - intSkip) >= (this.mintPageSize - 1))
            break;

        intIdx++;
    }

    dr.Close();

    // Populate Data Grid
    this.dgEmp.DataSource = ds.Tables["tblEmp"].DefaultView;

    // Show Status
    this.lblStatus.Text = (this.mintCurrentPage + 1).ToString() + 
                           " / " + this.mintPageCount.ToString();

    cmd.Dispose();
    ds.Dispose();
}

Here is the code for page navigation:

C#
private void goFirst()
{
    this.mintCurrentPage = 0;

    loadPage();
}

private void goPrevious()
{
    if (this.mintCurrentPage == this.mintPageCount)
        this.mintCurrentPage = this.mintPageCount - 1;

    this.mintCurrentPage--;

    if (this.mintCurrentPage < 1) 
        this.mintCurrentPage = 0;

    loadPage();
}

private void goNext()
{
    this.mintCurrentPage++;

    if (this.mintCurrentPage > (this.mintPageCount - 1))
        this.mintCurrentPage = this.mintPageCount - 1;

    loadPage();
}

private void goLast()
{
    this.mintCurrentPage = this.mintPageCount - 1;

    loadPage();
}

History

  • Released on November 9th 2006.

License

This article, along with any associated source code and files, is licensed under The Code Project Open License (CPOL)


Written By
Team Leader
India India
This member has not yet provided a Biography. Assume it's interesting and varied, and probably something to do with programming.

Comments and Discussions

 
Questionhit database with every page navigation? Pin
ashsanD4-Jul-13 0:14
ashsanD4-Jul-13 0:14 
Generalsimple and functional Pin
FernandoMartin16-Sep-09 3:43
FernandoMartin16-Sep-09 3:43 

General General    News News    Suggestion Suggestion    Question Question    Bug Bug    Answer Answer    Joke Joke    Praise Praise    Rant Rant    Admin Admin   

Use Ctrl+Left/Right to switch messages, Ctrl+Up/Down to switch threads, Ctrl+Shift+Left/Right to switch pages.