GridView嵌套GridView 级联删除(使用SqlDataSource删除版本)

来源:互联网 发布:网站美工都做什么 编辑:程序博客网 时间:2024/06/16 19:58
 

GridView嵌套GridView,对子GridView及父GridView级联删除的问题,使用SqlDataSource删除版本

 

  1. <%@ Page Language="C#" AutoEventWireup="true" CodeFile="GridViewNesting.aspx.cs" Inherits="GridViewNesting" %>  
  2. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">  
  3. <html xmlns="http://www.w3.org/1999/xhtml" >  
  4. <head runat="server">  
  5.     <title>GridViewNesting</title>  
  6. </head>  
  7. <body>  
  8.     <form id="form1" runat="server">  
  9.     <div>  
  10.     <asp:GridView ID="GridView1" runat="server" AutoGenerateColumns="False" DataKeyNames="au_id" DataSourceID="SqlDataSource1" OnRowDataBound="GridView1_RowDataBound" >  
  11.         <Columns>  
  12.             <asp:CommandField ShowEditButton="True" />  
  13.             <asp:CommandField ShowDeleteButton="True" />  
  14.             <asp:TemplateField HeaderText="au_id" >  
  15.                 <ItemTemplate>  
  16.                     <asp:Label id="Label1" runat="server" Text='<%# Eval("au_id")%>'></asp:Label>  
  17.                 </ItemTemplate>  
  18.             </asp:TemplateField>  
  19.             <asp:TemplateField  HeaderText="au_lname">  
  20.                 <ItemTemplate>  
  21.                     <asp:Label id="Label2" runat="server" Text='<%# Eval("au_lname")%>'></asp:Label>  
  22.                 </ItemTemplate>  
  23.             </asp:TemplateField>  
  24.             <asp:TemplateField  HeaderText="titleDetail">  
  25.                 <ItemTemplate>  
  26.                     <asp:GridView ID="GridView2" runat="server" AutoGenerateColumns="False" DataKeyNames="au_id,title_id" DataSourceID="SqlDataSource2">    
  27.                      <Columns>  
  28.                         <asp:CommandField ShowEditButton="True" />  
  29.                         <asp:CommandField ShowDeleteButton="True" />  
  30.                          <asp:TemplateField HeaderText="title_id" >  
  31.                              <ItemTemplate>  
  32.                                 <asp:Label id="Label1" runat="server" Text='<%# Eval("title_id")%>'></asp:Label>  
  33.                              </ItemTemplate>  
  34.                          </asp:TemplateField>  
  35.                          <asp:TemplateField  HeaderText="au_ord">  
  36.                              <ItemTemplate>  
  37.                                 <asp:Label id="Label2" runat="server" Text='<%# Eval("au_ord")%>'></asp:Label>  
  38.                              </ItemTemplate>  
  39.                          </asp:TemplateField>  
  40.                         </Columns>  
  41.                     </asp:GridView>  
  42.                     <asp:SqlDataSource ID="SqlDataSource2" runat="server" ConnectionString="Data Source=./sqlexpress;Initial Catalog=pubs;Integrated Security=True"  
  43.                         ProviderName="System.Data.SqlClient" SelectCommand="select au_id, title_id, au_ord from titleauthor where au_id = @au_id" DeleteCommand="delete from titleauthor where au_id = @au_id and title_id = @title_id">  
  44.                         <SelectParameters>  
  45.                             <asp:Parameter Name="au_id" />  
  46.                         </SelectParameters>  
  47.                         <DeleteParameters>  
  48.                             <asp:Parameter Name="au_id" />  
  49.                             <asp:Parameter Name="title_id" />  
  50.                         </DeleteParameters>  
  51.                     </asp:SqlDataSource>  
  52.             </ItemTemplate>  
  53.          </asp:TemplateField>  
  54.         </Columns>  
  55.     </asp:GridView>  
  56.         <asp:SqlDataSource ID="SqlDataSource1" runat="server" ConnectionString="Data Source=./sqlexpress;Initial Catalog=pubs;Integrated Security=True"  
  57.             ProviderName="System.Data.SqlClient" SelectCommand="select au_id, au_lname from authors" DeleteCommand="delete from titleauthor where au_id = @au_id;delete from authors where au_id = @au_id">  
  58.             <DeleteParameters>  
  59.                 <asp:Parameter Name="au_id" />  
  60.             </DeleteParameters>  
  61.         </asp:SqlDataSource>  
  62.     </div>  
  63.     </form>  
  64. </body>  
  65. </html>  

aspx.cs

  1. using System;   
  2. using System.Data;   
  3. using System.Configuration;   
  4. using System.Collections;   
  5. using System.Web;   
  6. using System.Web.Security;   
  7. using System.Web.UI;   
  8. using System.Web.UI.WebControls;   
  9. using System.Web.UI.WebControls.WebParts;   
  10. using System.Web.UI.HtmlControls;   
  11.   
  12. public partial class GridViewNesting : System.Web.UI.Page   
  13. {   
  14.     private void Page_Load(object sender, System.EventArgs e)   
  15.     {   
  16.   
  17.     }   
  18.   
  19.     protected void GridView1_RowDataBound(object sender, GridViewRowEventArgs e)   
  20.     {   
  21.         SqlDataSource sqlDataSource2;   
  22.         if (e.Row.RowType == DataControlRowType.DataRow)   
  23.         {   
  24.             sqlDataSource2 = e.Row.FindControl("SqlDataSource2"as SqlDataSource;   
  25.             if (sqlDataSource2 != null)   
  26.             {   
  27.                 sqlDataSource2.SelectParameters["au_id"].DefaultValue = (e.Row.DataItem as DataRowView)["au_id"].ToString();   
  28.             }   
  29.         }   
  30.     }   
  31. }