Gridview Control
Gridview display data in tabular format. Is widely used Asp.net controls and most popular and easy to use server control. Gridview not only display data, but also sorting, paging can be done in it. For styling Gridview , you can also apply Css in it .Gridview also allow inline editing, deleting data .You can display image in Gridview cell. It is possible to select a full row of a Gridview. Gridview may contain multiple keys and multiple data field.
Gridview bind data with data source and populate automatically. You can also programmatically populate Gridview and it's row and cells. Gridview data source maybe DataSet or a collection. When you bind a data source with Gridview, the column is generated automatically depending upon the data source. You can stop this functionality to make AutoGenerateColumns to false. Item template is a template of item which can be designed during design time. We will find an example of item template in later example. Gridview comes under the namespace System.Web.UI.WebControls
Here are some most common attributes of Gridview
Here is some example of GridView
1) Populate GridView
Default.aspx
Default.aspx.cs
Output :
2) Paging , sorting and auto generated
column of a gridview
3) GridView export to excel
4) GridView export to csv
Default.aspx
Output
Gridview display data in tabular format. Is widely used Asp.net controls and most popular and easy to use server control. Gridview not only display data, but also sorting, paging can be done in it. For styling Gridview , you can also apply Css in it .Gridview also allow inline editing, deleting data .You can display image in Gridview cell. It is possible to select a full row of a Gridview. Gridview may contain multiple keys and multiple data field.
Gridview bind data with data source and populate automatically. You can also programmatically populate Gridview and it's row and cells. Gridview data source maybe DataSet or a collection. When you bind a data source with Gridview, the column is generated automatically depending upon the data source. You can stop this functionality to make AutoGenerateColumns to false. Item template is a template of item which can be designed during design time. We will find an example of item template in later example. Gridview comes under the namespace System.Web.UI.WebControls
Here are some most common attributes of Gridview
Constructor | Gridview() | Initialised Gridview constructor to create a new instance of a Gridview. |
---|---|---|
Property | AllowPaging | This property allow paging automatically. |
Property | AllowSorting | This property allow Grid column to sort automatically. |
Property | AllowSorting | This property allow Grid column to sort automatically. |
Property | AutoGenerateColumns | This property allow Gridview to generate column automatically or not. |
Property | AutoGenerateDeleteButton | This property allowed Gridview to generate auto delete Button or not. |
Property | AutoGenerateSelectButton | This property allow Gridview to generate automatically select Button or not. |
Property | ClientID | Get client ID from HTML generated from server. The ID is generated from server to render HTML to identify this control. |
Property | CssClass | Get or Set Stylesheet class for Gridview. |
Property | DataSourceID | Get or Set control id of bound data. |
Method | DataBind | Bind the Gridview with data source. |
Method | DeleteRow | Delete record from data source with the help of index. |
Method | Dispose | Dispose the Gridview and release all memories consumed by the Gridview. |
Method | FindControl | Search for a server control with parameter to identify that control |
Event | Onload | Handle the event when the Gridview is load. |
Event | PageIndexChanged | Handle the event,when page index is changed |
Event | OnRowCommand | Raise an event when command is fire against a row. |
Event | onRowDelete | Raised an event when delete command is fire against a row |
Event | onRowUpdate | Raise an event, when update command is fired against an update command. |
Below is a script of table and some Sql to insert data in this table. The
script will create a table and fill with corresponding data. We are
going to create some simple application of Gridview, we will use this
table and data.
CREATE
TABLE
tbl_student
(
ID
INT
IDENTITY,
Name
VARCHAR(500),
Roll
INT,
Class
INT
)
GO
INSERT
INTO
tbl_student(Name,Roll,Class)
VALUES('Student1',123,2)
GO
INSERT
INTO
tbl_student(Name,Roll,Class)
VALUES('Student2',124,3)
GO
INSERT
INTO
tbl_student(Name,Roll,Class)
VALUES('Student3',125,4)
GO
INSERT
INTO
tbl_student(Name,Roll,Class)
VALUES('Student4',126,5)
GO
INSERT
INTO
tbl_student(Name,Roll,Class)
VALUES('Student5',127,6)
GO
INSERT
INTO
tbl_student(Name,Roll,Class)
VALUES('Student6',128,7)
GO
INSERT
INTO
tbl_student(Name,Roll,Class)
VALUES('Student7',129,9)
GO
INSERT
INTO
tbl_student(Name,Roll,Class)
VALUES('Student8',130,10)
Here is some example of GridView
1) Populate GridView
Default.aspx
<%@
Page
Language="C#"
AutoEventWireup="true"
CodeFile="Default2.aspx.cs"
Inherits="Default2"
%>
<!DOCTYPE
html
PUBLIC
"-//W3C//DTD
XHTML 1.0 Transitional//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html
xmlns="http://www.w3.org/1999/xhtml">
<head
runat="server">
<title></title>
</head>
<body>
<form
id="form1"
runat="server">
<div>
</div>
<asp:GridView
ID="GridView1"
runat="server">
</asp:GridView>
</form>
</body>
</html>
Default.aspx.cs
using
System;
using
System.Collections.Generic;
using
System.Data;
using
System.Data.SqlClient;
using
System.Web;
using
System.Web.UI;
using
System.Web.UI.WebControls;
public
partial
class
Default2
: System.Web.UI.Page
{
protected
void
Page_Load(object
sender, EventArgs
e)
{
string
conString = "Your
Conncetion String";
DataSet
ds = new
DataSet();
SqlDataAdapter
da = new
SqlDataAdapter("select
* from tbl_student ",
conString);
da.Fill(ds);
GridView1.DataSource
= ds;
GridView1.DataBind();
}
}
Output :
<%@
Page
Language="C#"
AutoEventWireup="true"
CodeFile="Default2.aspx.cs"
Inherits="Default2"
%>
<!DOCTYPE
html
PUBLIC
"-//W3C//DTD
XHTML 1.0 Transitional//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html
xmlns="http://www.w3.org/1999/xhtml">
<head
runat="server">
<title></title>
</head>
<body>
<form
id="form1"
runat="server">
<div>
</div>
<asp:GridView
ID="GridView1"
runat="server"
AllowPaging="True"
AllowSorting="True"
PageSize="5">
</asp:GridView>
</form>
</body>
</html>
using
System;
using
System.Collections.Generic;
using
System.Data;
using
System.Data.SqlClient;
using
System.Web;
using
System.Web.UI;
using
System.Web.UI.WebControls;
public
partial
class
Default2
: System.Web.UI.Page
{
protected
void
Page_Load(object
sender, EventArgs
e)
{
string
conString = "Your
Connection String";
DataSet
ds = new
DataSet();
SqlDataAdapter
da = new
SqlDataAdapter("select
* from tbl_student ",
conString);
da.Fill(ds);
GridView1.DataSource
= ds;
GridView1.DataBind();
}
}
3) GridView export to excel
Default.aspx
<%@
Page
Language="C#"
AutoEventWireup="true"
CodeFile="Default2.aspx.cs"
Inherits="Default2"
EnableEventValidation
=
"false"
EnableViewState="false"
ValidateRequest=
"false"
%>
<!DOCTYPE
html
PUBLIC
"-//W3C//DTD
XHTML 1.0 Transitional//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html
xmlns="http://www.w3.org/1999/xhtml">
<head
runat="server">
<title></title>
</head>
<body>
<form
id="form1"
runat="server">
<asp:GridView
ID="GridView1"
runat="server"
AllowPaging="True"
AllowSorting="True"
PageSize="5">
</asp:GridView>
<asp:Button
ID="btnExport"
runat="server"
oncommand="btnExport_Command"
Text="Export
to Exel"
/>
</form>
</body>
</html>
Default.aspx.cs
using
System;
using
System.Collections.Generic;
using
System.Data;
using
System.Data.SqlClient;
using
System.Web;
using
System.Web.UI;
using
System.Web.UI.WebControls;
using
System.IO;
public
partial
class
Default2
: System.Web.UI.Page
{
protected
void
Page_Load(object
sender, EventArgs
e)
{
string
conString = "your
connection string”;
DataSet
ds = new
DataSet();
SqlDataAdapter
da = new
SqlDataAdapter("select
* from tbl_student ",
conString);
da.Fill(ds);
GridView1.DataSource
= ds;
GridView1.DataBind();
}
protected
void
btnExport_Command(object
sender, CommandEventArgs
e)
{
Response.Clear();
Response.AddHeader("content-disposition",
"attachment;filename=MyExel.xls");
Response.Charset
= "";
Response.ContentType
= "application/vnd.xls";
StringWriter
StringWriter = new
System.IO.StringWriter();
HtmlTextWriter
HtmlTextWriter = new
HtmlTextWriter(StringWriter);
GridView1.RenderControl(HtmlTextWriter);
Response.Write(StringWriter.ToString());
Response.End();
}
public
override
void
VerifyRenderingInServerForm(Control
control)
{
}
}
Output
Output
4) GridView export to csv
Default.aspx
<%@
Page
Language="C#"
AutoEventWireup="true"
CodeFile="Default2.aspx.cs"
Inherits="Default2"
EnableEventValidation
=
"false"
EnableViewState="false"
ValidateRequest=
"false"
%>
<!DOCTYPE
html
PUBLIC
"-//W3C//DTD
XHTML 1.0 Transitional//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html
xmlns="http://www.w3.org/1999/xhtml">
<head
runat="server">
<title></title>
</head>
<body>
<form
id="form1"
runat="server">
<asp:GridView
ID="GridView1"
runat="server"
AllowPaging="True"
AllowSorting="True"
PageSize="5">
</asp:GridView>
<asp:Button
ID="btnExport"
runat="server"
oncommand="btnExport_Command"
Text="Export
to CSV"
/>
</form>
</body>
</html>
Default.aspx.cs
using
System;
using
System.Collections.Generic;
using
System.Data;
using
System.Data.SqlClient;
using
System.Web;
using
System.Web.UI;
using
System.Web.UI.WebControls;
using
System.IO;
using
System.Text;
public
partial
class
Default2
: System.Web.UI.Page
{
protected
void
Page_Load(object
sender, EventArgs
e)
{
string
conString = @"Data
Source=.\SQLEXPRESS;AttachDbFilename=C:\Users\abanerjee\Desktop\WebSite1\App_Data\Database.mdf;Integrated
Security=True;User Instance=True";
DataSet
ds = new
DataSet();
SqlDataAdapter
da = new
SqlDataAdapter("select
* from tbl_student ",
conString);
da.Fill(ds);
GridView1.DataSource
= ds;
GridView1.DataBind();
}
protected
void
btnExport_Command(object
sender, CommandEventArgs
e)
{
Response.Clear();
Response.Buffer
= true;
Response.AddHeader("content-disposition",
"attachment;filename=MyCSVFile.csv");
Response.Charset
= "";
Response.ContentType
= "application/text";
StringBuilder
sb = new
System.Text.StringBuilder();
for
(int
index = 0; index < GridView1.Columns.Count; index++)
{
sb.Append(GridView1.Columns[index].HeaderText
+ ',');
}
sb.Append("\r\n");
for
(int
i = 0; i < GridView1.Rows.Count; i++)
{
for
(int
k = 0; k < GridView1.HeaderRow.Cells.Count; k++)
{
sb.Append(GridView1.Rows[i].Cells[k].Text.Replace(",",
"")
+ ",");
}
sb.Append("\r\n");
}
Response.Output.Write(sb.ToString());
Response.Flush();
Response.End();
}
public
override
void
VerifyRenderingInServerForm(Control
control)
{
}
}
Output