C# 在C中编辑子嵌套gridview中的行

C# 在C中编辑子嵌套gridview中的行,c#,gridview,edit,C#,Gridview,Edit,我需要编辑嵌套子gridview上的行 这是我的代码,但编辑打开的始终是相同的id: 从'72'中sID所在的点表中选择* 如何解决这个问题 //On Gridview g1 <asp:TemplateField HeaderText="" Visible="false"> <ItemTemplate> <asp:Label ID="lblsID" Text='<%# Eval("sID") %>' runat="server">

我需要编辑嵌套子gridview上的行

这是我的代码,但编辑打开的始终是相同的id:

从'72'中sID所在的点表中选择*

如何解决这个问题

//On Gridview g1
<asp:TemplateField HeaderText="" Visible="false">
   <ItemTemplate>
      <asp:Label ID="lblsID" Text='<%# Eval("sID") %>' runat="server"></asp:Label>
   </ItemTemplate>
</asp:TemplateField>

protected void GridView2_RowEditing(object sender, GridViewEditEventArgs e)
{
    GridView g2 = (GridView)sender;
    g2.EditIndex = e.NewEditIndex;

    int customerId = (int)g1.DataKeys[e.NewEditIndex].Value;

    sql = @String.Format(" SELECT * FROM `doTable` ");
    sql += String.Format(" WHERE sID IN ('{0}') ", customerId);

    Response.Write(sql);

    g2.DataSource = GetData(sql);
    g2.DataBind();

}
请试试这个:

    protected void GridView2_RowEditing(object sender, GridViewEditEventArgs e)
    {
        GridView g2 = (GridView)sender;
        g2.EditIndex = e.NewEditIndex;

        GridViewRow gvCustomerRow = g2.NamingContainer as GridViewRow;
        int customerId = (int)g1.DataKeys[gvCustomerRow.RowIndex].Value;

        sql = @String.Format(" SELECT * FROM `doTable` ");
        sql += String.Format(" WHERE sID IN ('{0}') ", customerId);

        g2.DataSource = GetData(sql);
        g2.DataBind();
    }