Skip to main content

Deleting Row option with deleting file from server and database through gridview

First use gridview :

 <asp:GridView ID="grdAcademicResourceFilesView" runat="server" AutoGenerateColumns="False"
                            CellPadding="4" DataKeyNames="ID" ForeColor="#333333" GridLines="None" OnRowDeleting="grdAcademicResourceFilesView_RowDeleting"
                            Width="100%">
                            <RowStyle BackColor="#F7F6F3" ForeColor="#333333" />
                            <Columns>
                                <asp:BoundField DataField="Title" HeaderText="Title" SortExpression="Title" />
                                <asp:BoundField DataField="Name" HeaderText="Category Name" SortExpression="Name" />
                                <asp:BoundField DataField="ProgramCode" HeaderText="Program Code" SortExpression="ProgramCode" />
                                <asp:BoundField DataField="Semester" DataFormatString="Semester {0}" HeaderText="Term Id"
                                    SortExpression="Semester" />
                                <asp:BoundField DataField="UploadedFileName" HeaderText="File Name" SortExpression="UploadedFileName" />
                                <asp:BoundField DataField="CreatedBy" HeaderText="Uploaded By" SortExpression="CreatedBy" />
                                <asp:BoundField DataField="CreatedDate" DataFormatString="{0:d}" HeaderText="Upload Date"
                                    SortExpression="CreatedDate" />
                                <asp:BoundField DataField="CourseCode" HeaderText="Course Code" SortExpression="CourseCode" />
                                <asp:BoundField DataField="Remarks" HeaderText="Remarks" SortExpression="Remarks" />
                                <asp:TemplateField ShowHeader="False">
                                    <ItemTemplate>
                                        <asp:LinkButton ID="LinkButton1" runat="server" CausesValidation="False" CommandName="Delete"
                                            OnClientClick="return confirm ('Are you sure to delete this record');" Text="Delete"></asp:LinkButton>
                                    </ItemTemplate>
                                </asp:TemplateField>
                            </Columns>
                            <FooterStyle BackColor="#5D7B9D" Font-Bold="True" ForeColor="White" />
                            <PagerStyle BackColor="#284775" ForeColor="White" HorizontalAlign="Center" />
                            <SelectedRowStyle BackColor="#E2DED6" Font-Bold="True" ForeColor="#333333" />
                            <HeaderStyle BackColor="#5D7B9D" Font-Bold="True" ForeColor="White" />
                            <EditRowStyle BackColor="#999999" />
                            <AlternatingRowStyle BackColor="White" ForeColor="#284775" />
                        </asp:GridView>

Then add sqldata source to attach to it.
 <asp:SqlDataSource ID="SqlDataSource1" runat="server" ConnectionString="<%$ ConnectionStrings:LCODLConnectionString %>"
                            SelectCommand="LcOdlViewAcademicUploadedFiles" SelectCommandType="StoredProcedure"></asp:SqlDataSource>

Then create event of gridview ROW DELETING and paste following code in code behind model

  protected void grdAcademicResourceFilesView_RowDeleting(object sender, GridViewDeleteEventArgs e)
    {
        string rowID = Convert.ToString(grdAcademicResourceFilesView.DataKeys[e.RowIndex]["ID"]);
        string uploadedFileName = grdAcademicResourceFilesView.Rows[e.RowIndex].Cells[4].Text;
        if (!string.IsNullOrEmpty(uploadedFileName))
        {
            using (SqlConnection con = new SqlConnection(ConfigurationManager.ConnectionStrings["LCODLConnectionString"].ConnectionString))
            {
                SqlTransaction tran = null;
                if (con.State == ConnectionState.Closed)
                {
                    con.Open();
                }
                tran = con.BeginTransaction();
                bool canDeleteFile = false;
                try
                {
                    SqlParameter[] param = new SqlParameter[2];
                    param[0] = new SqlParameter("@id", rowID);
                    param[1] = new SqlParameter("@canDelete", SqlDbType.Bit);
                    param[1].Direction = ParameterDirection.Output;
                    SqlHelper.ExecuteNonQuery(tran, CommandType.StoredProcedure, "LcOdlDeleteUploadedAcademicFile", param);
                    canDeleteFile = Convert.ToBoolean(param[1].Value);
                    tran.Commit();
                }
                catch (SqlException ex)
                {
                    tran.Rollback();
                    ScriptManager.RegisterStartupScript(grdAcademicResourceFilesView, grdAcademicResourceFilesView.GetType(), "DeletingError", "alert('Some thing went wrong while deleting file. Please try again later');", true);
                    return;
                }
                finally
                {
                    con.Close();
                }
                //Now going To Deleet file from filesystem

                string Rootfolder = Server.MapPath("~/IpSyllabusSchemas");
                string FilePathWithName = string.Format("{0}\\{1}", Rootfolder, uploadedFileName);
                if (canDeleteFile)
                {
                    if (File.Exists(FilePathWithName))
                    {
                        try
                        {
                            File.Delete(FilePathWithName);
                        }
                        catch (Exception ex)
                        {
                            tran.Rollback();
                            ScriptManager.RegisterStartupScript(grdAcademicResourceFilesView, grdAcademicResourceFilesView.GetType(), "DeletingError", "alert('Some thing went wrong while deleting file. Please try again later');", true);
                            return;
                        }
                    }
                }

                grdAcademicResourceFilesView.DataSource = GetUploadedFiles();
                grdAcademicResourceFilesView.DataBind();
            }

        }
    }

Done :)

Comments

Popular posts from this blog

show image in asp.net form from database

In order to show image from database to webform first add an image control in webpage.   <asp:Image ID="imgStudentImage" runat="server" Height="157px" Width="160px" /> Then add new webform to read image from database for example displayimage.aspx and in code behind model write the following code. public string str = //your string     public SqlConnection conn;     public SqlCommand sql = new SqlCommand();     public SqlDataReader dr;     public string strSQL;     protected void Page_Load(object sender, EventArgs e)     {         conn = new SqlConnection(str);         conn.Open();         long id = Convert.ToInt64(Request.QueryString["mId"]);         strSQL = "";         strSQL = strSQL + " SELECT snap from S...

Export Doc,Access,Image,CSV,Excel,Pdf,XML,HTML,Text,Print of Gridview in Asp.net

First import itextsharp.dll in the solution and use three namespces (basically for pdf) using iTextSharp.text; using iTextSharp.text.pdf; using iTextSharp.text.html.simpleparser;          Then Use the following code :- on each button  click  protected void Page_Load(object sender, EventArgs e)         {             if (!Page.IsPostBack)             {                 BindGridDetails(GridView1);             }         }                 protected DataTable BindGridDetails(GridView GridView1)         {   ...

Ip Sec Internet Security Basic Structure

The IPsec suite is an  open standard . IPsec uses the following  protocols  to perform various functions: Authentication Headers (AH)  provide connectionless  integrity  and data origin  authentication  for IP  datagrams  and provides protection against  replay attacks . Encapsulating Security Payloads (ESP)  provide  confidentiality , data-origin  authentication , connectionless  integrity , an anti-replay service (a form of partial sequence integrity), and limited traffic-flow confidentiality. Security Associations (SA)  provide the bundle of algorithms and data that provide the parameters necessary to AH and/or ESP operations. The  Internet Security Association and Key Management Protocol  (ISAKMP) provides a framework for authentication and key exchange, with actual authenticated keying material provided either by manual configuration with pre-shared keys,  Internet Key Exch...