Skip to main content

Fill Datatable and Bind GridView Using Data Reader in ASP.Net C#.Net VB.Net

In this article i am going to explain about how to fill the datatable using datareader and bind that datatable to gridview.

Datareader is read only forward only way of reading data. Compare to dataset datareader is fast in terms of reading data. To fill the datatable using datareader DataTable.Load() methaod is used in that datareader object is passed as the argument.

Create a new asp.net application and add a grid view in to display the details from the students table. Below is the html code used.

Fill Datatable Using Data Reader


For explanation purpose i have created a table called student and inserted some sample records. Below is the script used to create table and insert record into table.

CREATE TABLE Students
(
Id INT IDENTITY PRIMARY KEY,
Name VARCHAR(100),
Class TINYINT,
Section CHAR(1),
JoinedDate DATE
)
GO

INSERT INTO Students(Name,Class,Section,JoinedDate)
VALUES('Student-1',10,'A','2009-06-01')

INSERT INTO Students(Name,Class,Section,JoinedDate)
VALUES('Student-2',9,'B','2014-06-01')

INSERT INTO Students(Name,Class,Section,JoinedDate)
VALUES('Student-3',11,'C','2011-06-01')

INSERT INTO Students(Name,Class,Section,JoinedDate)
VALUES('Student-4',12,'D','2012-06-01')

INSERT INTO Students(Name,Class,Section,JoinedDate)
VALUES('Student-5',8,'E','2005-06-01')
GO

Before moving ahead include the connection string element in the web.config file.


  


And now include the below namespaces to access the sqlconnection, datatable and configuration objects

C#.Net:
using System.Data;
using System.Data.SqlClient;
using System.Configuration;

VB.Net:
Imports System.Data
Imports System.Data.SqlClient
Imports System.Configuration

On pageload event i am fetching the data from the students table using datareader and filling it to the datatable using DataTable.Load() method and then binding the same datatable to gridview. Below is the code.

C#.Net:
protected void Page_Load(object sender, EventArgs e)
{
try
{
string connectionString = ConfigurationManager.ConnectionStrings["mydsn"].ConnectionString;
using (SqlConnection conn = new SqlConnection(connectionString))
{
    using (SqlCommand cmd = new SqlCommand())
    {
        cmd.Connection = conn;
        cmd.CommandText = "Select * from students";
        cmd.CommandType = CommandType.Text;
        if (conn.State == ConnectionState.Closed)
            conn.Open();
        SqlDataReader dReader = cmd.ExecuteReader(CommandBehavior.CloseConnection);
        DataTable dTable = new DataTable("Students");
        dTable.Load(dReader);
        grdReasults.DataSource = dTable;
        grdReasults.DataBind();
        cmd.Dispose();
        conn.Close();
    }
}
}
catch (Exception ex)
{
// handle error
}
}

VB.Net:
Protected Sub Page_Load(sender As Object, e As EventArgs)
 Try
  Dim connectionString As String = ConfigurationManager.ConnectionStrings("mydsn").ConnectionString
  Using conn As New SqlConnection(connectionString)
   Using cmd As New SqlCommand()
    cmd.Connection = conn
    cmd.CommandText = "Select * from students"
    cmd.CommandType = CommandType.Text
    If conn.State = ConnectionState.Closed Then
     conn.Open()
    End If
    Dim dReader As SqlDataReader = cmd.ExecuteReader(CommandBehavior.CloseConnection)
    Dim dTable As New DataTable("Students")
    dTable.Load(dReader)
    grdReasults.DataSource = dTable
    grdReasults.DataBind()
    cmd.Dispose()
    conn.Close()
   End Using
  End Using
   ' handle error
 Catch ex As Exception
 End Try
End Sub

The output will look like

Download Source

Comments

Popular posts from this blog

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)     {         sb.Append( "Minus " );         inputNo = -inputNo;     }     string [] words0 = { "" , "One " ,

C# code to send mail using smtp from gmail,yahoo mail and live mail

Introduction: In my previous article I have explained about   How to bind/Unbind events in jQuery . In this article I am going to explain about how to send mail from ASP.Net using gmail,yahoomail and live mail credentials. Explanation: First Include the below namespaces in your code behind file. using System; using System.Net; using System.Net.Mail;

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