In this poat I expalined Basic evnets of GridView Like Insert, Edit and Update.
I have one gridview I need to write code to insert data into gridview after that I need to edit that gridview data and update it and if I want to delete the record in grdview we need to delete record simply by click on delete button of particular row to achieve these functionalities I have used some of gridview events those are
Explaination of GridView:-
AutoGenerateColumns: This property accepts only a Boolean value. The default value is true. When we set it to False that means the BoundField objects are not created automatically; we will create the fields manually.
DataKeyNames: This property is used to associate a value with each row in the GridView. Here we can assign the name of a single database column or more than one column. When we assign more than one database columns then they are specified separated by commas. It represents datakey values. By this we uniquely identifiy records in GridView rows.
<Columns>: It is a collection of columns that the GridView contains. By this we can control what GridView columns are displayed, which means we can change the order of the appearance of the columns.
<asp:TemplateField>: Is used to add ASP.Net controls in GridView rows. One TemplateField represents one column in the GridView. It customizes the appearance of the UI in the GridView. It is useful when we are using a GridView to edit a database record.
<ItemTemplate>: It specifies the contents that are displayed in a TemplateField object. It displays a layout for the TemplateField.
<EditItemTemplate>: It also specifies contents that are displayed in a TemplateField but in EditMode.
Eval Function: It is a method that is used to display data. In this method we pass a database field name as an argument and that database field is displayed by this.
<asp:CommandField>: It is a special field that displays command buttons to perform selecting, editing, inserting and deleting.
.CS file:-
First i will set connection String and SQl-Connection
2. Let me Insert some records:-
3. And Let insert two more records and then will update the last record:-
See in the Image I added two more records and after that I Clicked on Edit button. For EmpId 's 3 I added last name as Singh.
4. See below after update the EmpId's 3 details
5. Now let Delete Second one record from gridView:-
See in above image Second record deleted from the gridView.
In the above article I try to explain the Events of GridView in asp.net c# with example. I hope its useful to you. Please
post your feedback, question, or comments about this article.
I have one gridview I need to write code to insert data into gridview after that I need to edit that gridview data and update it and if I want to delete the record in grdview we need to delete record simply by click on delete button of particular row to achieve these functionalities I have used some of gridview events those are
- OnRowComand
- OnRowEditing
- OnRowCancelingEdit
- OnRowUpdating
- OnRowDeleting
First Here I writing a gridview code:-
.ASPX file:-
<asp:Content ID="BodyContent" ContentPlaceHolderID="MainContent" runat="server">
<h2><%: Title %>.</h2>
<h3>Demp Application</h3>
<p>Grid View:- Insert, Edit, Delete Events</p>
<div>
<asp:GridView ID="EmpGridView" Width="700px" runat="server" AutoGenerateColumns="False"
DataKeyNames="EmpId"
onrowcancelingedit="EmpGridView_RowCancelingEdit"
ShowFooter="True"
onrowediting="EmpGridView_RowEditing"
onrowdeleting="EmpGridView_RowDeleting"
onrowupdating="EmpGridView_RowUpdating"
onrowcommand="EmpGridView_RowCommand">
<Columns>
<asp:TemplateField HeaderText="Edit"
FooterStyle-HorizontalAlign="Center">
<EditItemTemplate>
<asp:ImageButton ID="imgbtnUpdate" CommandName="Update" runat="server" ImageUrl="~/Images/update.gif"
ToolTip="Update"
Height="20px"
Width="50px"
/>
<asp:ImageButton ID="imgbtnCancel" runat="server" CommandName="Cancel" ImageUrl="~/Images/Exit.gif"
ToolTip="Cancel"
Height="20px"
Width="50px"
/>
</EditItemTemplate>
<ItemTemplate>
<asp:ImageButton ID="imgbtnEdit" CommandName="Edit" runat="server" ImageUrl="~/Images/Edit.png"
ToolTip="Edit"
Height="20px"
Width="50px"
/>
<asp:ImageButton ID="imgbtnDelete" CommandName="Delete" Text="Edit" runat="server" ImageUrl="~/Images/delete.gif"
ToolTip="Delete"
Height="20px"
Width="50px"
/>
</ItemTemplate>
<FooterTemplate>
<asp:ImageButton ID="imgbtnAdd" runat="server" ImageUrl="~/Images/addnew.png" CommandName="AddNew"
Width="90px"
Height="30px"
ToolTip="Add new
User" ValidationGroup="validaiton" />
</FooterTemplate>
</asp:TemplateField>
<asp:TemplateField HeaderText="EmpId">
<ItemTemplate> <%#Eval("EmpId") %> </ItemTemplate>
</asp:TemplateField>
<asp:TemplateField HeaderText="Name">
<ItemTemplate> <%#Eval("EmpName") %></ItemTemplate>
<EditItemTemplate>
<asp:TextBox ID="txtEmpName"
runat="server"
Text='<%#Eval("EmpName") %>'></asp:TextBox>
</EditItemTemplate>
<FooterTemplate>
<asp:TextBox ID="txtNewEmpName"
runat="server"/>
<asp:RequiredFieldValidator
ID="empname"
runat="server"
ControlToValidate="txtNewEmpName"
Text="*" ValidationGroup="validaiton"
ForeColor="Red"/>
</FooterTemplate>
</asp:TemplateField>
<asp:TemplateField HeaderText="Salary">
<ItemTemplate> <%#Eval("EmpSalary") %>
</ItemTemplate>
<EditItemTemplate>
<asp:TextBox ID="txtEmpSalary"
runat="server"
Text='<%#Eval("EmpSalary") %>'></asp:TextBox>
</EditItemTemplate>
<FooterTemplate>
<asp:TextBox ID="txtNewEmpSalary"
runat="server"/>
<asp:RequiredFieldValidator
ID="empsalary"
runat="server"
ControlToValidate="txtNewEmpSalary"
Text="*" ValidationGroup="validaiton"
ForeColor="Red"/>
</FooterTemplate>
</asp:TemplateField>
<asp:TemplateField HeaderText="Age">
<ItemTemplate> <%#Eval("Age") %> </ItemTemplate>
<EditItemTemplate>
<asp:TextBox ID="txtAge" runat="server"
Text='<%#Eval("Age") %>'></asp:TextBox>
</EditItemTemplate>
<FooterTemplate>
<asp:TextBox ID="txtNewAge"
runat="server"/>
<asp:RequiredFieldValidator
ID="empAge"
runat="server"
ControlToValidate="txtNewAge"
Text="*" ValidationGroup="validaiton"
ForeColor="Red"/>
</FooterTemplate>
</asp:TemplateField>
</Columns>
</asp:GridView>
</div>
<div>
<asp:Label ID="lblresult"
runat="server"
Text=""></asp:Label>
</div>
</asp:Content>
Design:-
Design:-
Explaination of GridView:-
AutoGenerateColumns: This property accepts only a Boolean value. The default value is true. When we set it to False that means the BoundField objects are not created automatically; we will create the fields manually.
DataKeyNames: This property is used to associate a value with each row in the GridView. Here we can assign the name of a single database column or more than one column. When we assign more than one database columns then they are specified separated by commas. It represents datakey values. By this we uniquely identifiy records in GridView rows.
<Columns>: It is a collection of columns that the GridView contains. By this we can control what GridView columns are displayed, which means we can change the order of the appearance of the columns.
<asp:TemplateField>: Is used to add ASP.Net controls in GridView rows. One TemplateField represents one column in the GridView. It customizes the appearance of the UI in the GridView. It is useful when we are using a GridView to edit a database record.
<ItemTemplate>: It specifies the contents that are displayed in a TemplateField object. It displays a layout for the TemplateField.
<EditItemTemplate>: It also specifies contents that are displayed in a TemplateField but in EditMode.
Eval Function: It is a method that is used to display data. In this method we pass a database field name as an argument and that database field is displayed by this.
<asp:CommandField>: It is a special field that displays command buttons to perform selecting, editing, inserting and deleting.
.CS file:-
First i will set connection String and SQl-Connection
static String conStr =
WebConfigurationManager.ConnectionStrings["TestWebCon"].ConnectionString.ToString();
static SqlConnection
con = new SqlConnection(conStr);
// First time Bind GridView on Page Load
protected void
Page_Load(object sender, EventArgs e)
{
if (!IsPostBack)
{
bingGrid();
}
}
// Bind method
public void
bingGrid()
{
SqlCommand cmd = new
SqlCommand("[dbo].[getEmployee]",
con);
SqlDataAdapter da = new
SqlDataAdapter(cmd);
DataSet ds = new DataSet();
da.Fill(ds);
if (ds.Tables[0].Rows.Count > 0)
{
EmpGridView.DataSource = ds.Tables[0];
EmpGridView.DataBind();
}
else
{
ds.Tables[0].Rows.Add(ds.Tables[0].NewRow());
EmpGridView.DataSource = ds.Tables[0];
EmpGridView.DataBind();
int columncount =
EmpGridView.Rows[0].Cells.Count;
EmpGridView.Rows[0].Cells.Clear();
EmpGridView.Rows[0].Cells.Add(new
TableCell());
EmpGridView.Rows[0].Cells[0].ColumnSpan = columncount;
EmpGridView.Rows[0].Cells[0].Text = "No
Records Found";
con.Close();
}
}
Event 1:- On this RowComand events I insert new record
protected void
EmpGridView_RowCommand(object sender,
GridViewCommandEventArgs e)
{
if (e.CommandName.Equals("AddNew"))
{
TextBox txtEmpName = (TextBox)EmpGridView.FooterRow.FindControl("txtNewEmpName");
TextBox txtEmpSalary = (TextBox)EmpGridView.FooterRow.FindControl("txtNewEmpSalary");
TextBox txtAge = (TextBox)EmpGridView.FooterRow.FindControl("txtNewAge");
con.Open();
SqlCommand cmd = new SqlCommand("[dbo].[InsertEmployee]", con);
cmd.CommandType = CommandType.StoredProcedure;
cmd.Parameters.AddWithValue("@EmpName
", txtEmpName.Text);
cmd.Parameters.AddWithValue("@EmpSalary
", txtEmpSalary.Text);
cmd.Parameters.AddWithValue("@EmpAge
", txtAge.Text);
//Sql Command Class method return effected
rows use for insert,update, delete
int result = cmd.ExecuteNonQuery();
con.Close();
if (result == 1)
{
bingGrid();
lblresult.ForeColor = System.Drawing.Color.Green;
lblresult.Text = txtEmpName.Text + " Details inserted successfully";
}
else
{
lblresult.ForeColor = System.Drawing.Color.Red;
lblresult.Text = txtEmpName.Text + "
Details not inserted";
}
}
****** // If you want to update in side rowcommand event then this is the below code
protected void GridView1_RowCommand(object sender, GridViewCommandEventArgs e)
{
try
{
if (e.CommandName == "Edit")
{
ImageButton img = (ImageButton)e.CommandSource as ImageButton;
GridViewRow row = img.NamingContainer as GridViewRow;
TextBox2.Text = ((Label)row.FindControl("txtEditTimeDepart")).Text;
}
}
catch (Exception ex)
{
lblstatus.Text = "Error" + ex.ToString();
}
}
****** // If you want to update in side rowcommand event then this is the below code
protected void GridView1_RowCommand(object sender, GridViewCommandEventArgs e)
{
try
{
if (e.CommandName == "Edit")
{
ImageButton img = (ImageButton)e.CommandSource as ImageButton;
GridViewRow row = img.NamingContainer as GridViewRow;
TextBox2.Text = ((Label)row.FindControl("txtEditTimeDepart")).Text;
}
}
catch (Exception ex)
{
lblstatus.Text = "Error" + ex.ToString();
}
}
}
Event 2:- This event enable the editing in Gridview
protected void
EmpGridView_RowEditing(object sender,
GridViewEditEventArgs e)
{
EmpGridView.EditIndex = e.NewEditIndex;
bingGrid();//Fill GridView again call method
}
Event 3:- In this event you can cancel the editing
protected void
EmpGridView_RowCancelingEdit(object sender,GridViewCancelEditEventArgs e) {
EmpGridView.EditIndex = -1;
bingGrid();//Fill GridView again call method
}
Event 4:- This evnets allow you to save updates.
protected void EmpGridView_RowUpdating(object
sender, GridViewUpdateEventArgs e)
{
//Get Each Row unique value from DataKeyNames
int empid = Convert.ToInt32(EmpGridView.DataKeys[e.RowIndex].Value.ToString());
//get TextBox Value in EditItemTemplet that row is clicked
string name =
((TextBox)EmpGridView.Rows[e.RowIndex].FindControl("txtEmpName")).Text;
string Salary =
((TextBox)EmpGridView.Rows[e.RowIndex].FindControl("txtEmpSalary")).Text;
string Age =
((TextBox)EmpGridView.Rows[e.RowIndex].FindControl("txtAge")).Text;
con.Open();
SqlCommand cmd = new
SqlCommand("[dbo].[UpdateEmpDetails]",
con);
cmd.CommandType = CommandType.StoredProcedure;
cmd.Parameters.AddWithValue("@EmpId
", empid);
cmd.Parameters.AddWithValue("@EmpName
", name);
cmd.Parameters.AddWithValue("@EmpSal
", Salary);
cmd.Parameters.AddWithValue("@EmpAge
", Age);
//Sql Command Class method return effected rows use for
insert,update, delete
cmd.ExecuteNonQuery();
con.Close();
// no row in edit mode
EmpGridView.EditIndex = -1;
//call method for agin fill grid after update
lblresult.ForeColor = System.Drawing.Color.Green;
lblresult.Text = " Details updated
successfully";
bingGrid();
}
Event 5:- This evnet allow you to check the validation and delete record.
protected void
EmpGridView_RowDeleting(object sender, GridViewDeleteEventArgs
e)
{
int empid = Convert.ToInt32(EmpGridView.DataKeys[e.RowIndex].Value.ToString());
con.Open();
SqlCommand cmd = new
SqlCommand("[dbo].[DeleteEmployee]",
con);
cmd.CommandType = CommandType.StoredProcedure;
cmd.Parameters.AddWithValue("@EmpId
", empid);
cmd.ExecuteNonQuery();
con.Close();
lblresult.ForeColor = System.Drawing.Color.Green;
lblresult.Text = " Details deleted
successfully";
bingGrid();
}
}
Now Let me create a table EmployeeMaster:-
CREATE TABLE [dbo].[tblEmpMaster](
[EmpID] [int] IDENTITY(1,1) NOT NULL,
[EmpName] [varchar](100) NOT NULL,
[EmpSalary] [int] NULL,
[Age] [int] NULL,
)
And Now I need to create Stored Procedures to Insert, Delete and Update data in above table
SP to Insert :-
CREATE Procedure [dbo].[InsertEmployee]
(
@EmpName varchar(50),
@EmpSalary int,
@EmpAge int
)
as
begin
declare @EmpID int=(Select isnull(max(EmpID),0)+1 from [dbo].[tblEmpMaster])
Insert into [dbo].[tblEmpMaster](EmpID,EmpName,EmpSalary,Age)
Values(@EmpID,@EmpName,@EmpSalary,@EmpAge)
end
SP to Delete :-
Create Procedure [dbo].[DeleteEmployee]
(@EmpId varchar(50))
as
begin
Delete FROM [Employee].[dbo].[tblEmpMaster] where
EmpID=@EmpId
end
CREATE Procedure [dbo].[getEmployee]
as
begin
SELECT [EmpID],[EmpName],[EmpSalary],[Age] FROM [Employee].[dbo].[tblEmpMaster]
end
SP to Update :-
CREATE Procedure [dbo].[UpdateEmpDetails]
(@EmpId varchar(50),
@empName varchar(50),
@EmpSal int,
@EmpAge int)
as
begin
update [Employee].[dbo].[tblEmpMaster]
set
EmpName=@EmpName,
EmpSalary=@empSal,
Age=@EmpAge
where EmpID=@EmpId
end
2. Let me Insert some records:-
3. And Let insert two more records and then will update the last record:-
See in the Image I added two more records and after that I Clicked on Edit button. For EmpId 's 3 I added last name as Singh.
4. See below after update the EmpId's 3 details
5. Now let Delete Second one record from gridView:-
See in above image Second record deleted from the gridView.
In the above article I try to explain the Events of GridView in asp.net c# with example. I hope its useful to you. Please
post your feedback, question, or comments about this article.