In this programming tutorial you will learn how to delete the records in database using 3-tier architecture in asp.net with c#. For beginners ,I strongly recommend to read this tutorial 3-Tier Architecture in asp.net using c# first to get basics of 3-tier architecture in asp.net. So let’s begin, have a look over .aspx page
Delete records in database using 3-tier architecture in asp.net with c#
delete-records.aspx
As you have seen, we have an asp:gridview control in our web page. We have four template fields in it, these are rollNo, firstName, lastName and Delete image to delete the records. The main thing you must have to notice is the OnRowDeleting event of gridview. Through this event we will delete the records from database. So let’s have a look over its c# code behind file.
delete-records.aspx.cs
BusStudent.cs
Every thing is self explanatory and I will not go into any details as I already have written two tutorials 3-Tier Architecture in asp.net using c# and Insertion of records in database using 3-tier architecture in asp.net with c#.
If anything is not cleared then please read these above mentioned tutorials first. So this is the way to delete records in database using 3-tier architecture in asp.net with c#.
I love your feedback.
delete-records.aspx
- <%@ Page Language="C#" AutoEventWireup="true" CodeFile="delete-records.aspx.cs" Inherits="delete_records" %>
- <!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> Delete records in database using 3-tier architecture in asp.net with c#</title>
- </head>
- <body>
- <form id="form1" runat="server">
- <asp:GridView ID="GridView1" runat="server" EnableTheming="false" AutoGenerateColumns="false"
- GridLines="None" Width="100%" OnRowDeleting="GridView1_RowDeleting"
- >
- <Columns>
- <asp:TemplateField HeaderText="Roll No" HeaderStyle-Width="10%" HeaderStyle-HorizontalAlign="Center">
- <ItemTemplate>
- <asp:Label ID="lblRollNo" runat="server" EnableTheming="false" Text='<%# Bind("rollNo")%>'></asp:Label>
- </ItemTemplate>
- <ItemStyle HorizontalAlign="Center" />
- </asp:TemplateField>
- <asp:TemplateField HeaderText="First Name" HeaderStyle-Width="15%" HeaderStyle-HorizontalAlign="Left">
- <ItemTemplate>
- <asp:Label ID="lblFirstName" runat="server" EnableTheming="false" Text='<%# Bind("firstName")%>'></asp:Label>
- </ItemTemplate>
- <ItemStyle HorizontalAlign="Left" />
- </asp:TemplateField>
- <asp:TemplateField HeaderText="Last Name" HeaderStyle-Width="15%" HeaderStyle-HorizontalAlign="Left">
- <ItemTemplate>
- <asp:Label ID="lblLastName" runat="server" EnableTheming="false" Text='<%# Bind("lastName")%>'></asp:Label>
- </ItemTemplate>
- <ItemStyle HorizontalAlign="Left" />
- </asp:TemplateField>
- <asp:TemplateField HeaderText="Gender" HeaderStyle-Width="15%" HeaderStyle-HorizontalAlign="Left">
- <ItemTemplate>
- <asp:Label ID="lblGender" runat="server" EnableTheming="false" Text='<%# Bind("gender")%>'></asp:Label>
- </ItemTemplate>
- <ItemStyle HorizontalAlign="Left" />
- </asp:TemplateField>
- <asp:TemplateField HeaderText="Delete" HeaderStyle-Width="10%" HeaderStyle-HorizontalAlign="Center">
- <ItemTemplate>
- <asp:Label ID="lblDelete" Visible="false" Text='<%# Bind("rollNo")%>' runat="server"></asp:Label>
- <asp:ImageButton runat="server" ID="img" ImageUrl="images/delete.gif" CommandName="Delete"
- OnClientClick="return window.confirm('Are you sure you want to delete this record?')" />
- </ItemTemplate>
- <ItemStyle HorizontalAlign="Center" />
- </asp:TemplateField>
- </Columns>
- </asp:GridView>
- </form>
- </body>
- </html>
delete-records.aspx.cs
- using System;
- using System.Collections;
- using System.Configuration;
- using System.Data;
- using System.Web;
- using System.Web.Security;
- using System.Web.UI;
- using System.Web.UI.HtmlControls;
- using System.Web.UI.WebControls;
- using System.Web.UI.WebControls.WebParts;
- using BusinessLayer;//Don’t forget to include this namespace
- public partial class delete_records : System.Web.UI.Page
- {
- BusStudent _objStudent = new BusStudent();
- protected void Page_Load(object sender, EventArgs e)
- {
- if (!Page.IsPostBack)
- {
- BindGrid();
- }
- }
- public void BindGrid()
- {
- _objStudent.GetStudentRecords();
- GridView1.DataSource = _objStudent.StudentDS.Tables["studentrecords"];
- GridView1.DataBind();
- }
- protected void GridView1_RowDeleting(object sender, GridViewDeleteEventArgs e)
- {
- int index = e.RowIndex;
- GridViewRow row = GridView1.Rows[index];
- //The asp:label just before delete image
- Label lbl = (Label)row.FindControl("lblDelete");
- int rollNo = Convert.ToInt32(lbl.Text);
- //Deleting Records From Database
- _objStudent.DeleteStudentRows(rollNo);
- //Again Populating Gridview after records deletion
- BindGrid();
- }
- }
- using System;
- using System.Collections.Generic;
- using System.Text;
- using System.Data;
- using DataAccessLayer;//Donot forget to import this namespace
- namespace BusinessLayer
- {
- public class BusStudent
- {
- DbAccess _dbAccess = new DbAccess();
- private DataSet _StudentDS = new DataSet();
- public DataSet StudentDS
- {
- get
- {
- return _StudentDS;
- }
- set
- {
- _StudentDS = value;
- }
- }
- public void GetStudentRecords()
- {
- try
- {
- string strQuery = "select rollNo,firstName,lastName,gender from web_tbl_student";
- if (_StudentDS.Tables.Contains("studentrecords"))
- {
- _StudentDS.Tables["studentrecords"].Clear();
- }
- _dbAccess.selectQuery(_StudentDS, strQuery, "studentrecords");
- }
- catch (Exception ex)
- {
- throw ex;
- }
- }
- //Function to delete records from database, in this example I used MS SQL SERVER as a backend database
- public void DeleteStudentRows(int rollNo)
- {
- try
- {
- // I will always recommend you to not delete the records physically
- string strQuery = "delete from web_tbl_student where rollNo='"+ rollNo +"'";
- _dbAccess.executeQuery(strQuery);
- }
- catch (Exception ex)
- {
- throw ex;
- }
- }
- }
- }
Every thing is self explanatory and I will not go into any details as I already have written two tutorials 3-Tier Architecture in asp.net using c# and Insertion of records in database using 3-tier architecture in asp.net with c#.
If anything is not cleared then please read these above mentioned tutorials first. So this is the way to delete records in database using 3-tier architecture in asp.net with c#.
I love your feedback.
No comments:
Post a Comment