【问题标题】:Can't Delete row from gridview using command name无法使用命令名称从 gridview 中删除行
【发布时间】:2013-12-07 09:32:14
【问题描述】:

多年来,我一直试图通过命令名称删除 gridview 中的行,但我一直无法做到这一点。

在 gridview 行命令中,我添加了一些如代码所示的内容,用于删除 gridview 行,那么如何删除该行?

protected void Page_Load(object sender, EventArgs e)
{
    SqlConnection con = new SqlConnection("connectionstring1");
    string str;
    str = "select * from Products INNER JOIN orders on Products.picID=orders.productID";
    SqlCommand cmd = new SqlCommand(str, con);
    con.Open();

    DataTable dt = new DataTable();
    dt.Columns.Add(new DataColumn("picID", typeof(int)));
    dt.Columns.Add(new DataColumn("title", typeof(string)));
    dt.Columns.Add(new DataColumn("price", typeof(int)));
    dt.Columns.Add(new DataColumn("dateAdded", typeof(DateTime)));
    dt.Columns.Add(new DataColumn("picURL", typeof(string)));
    SqlDataReader reader = cmd.ExecuteReader();
    while (reader.Read())
    {

        DataRow dr = dt.NewRow();
        dr["picID"] = Convert.ToInt32(reader["picID"]);
        dr["title"] = reader["title"];
        dr["price"] = Convert.ToInt32(reader["price"]);
        dr["dateAdded"] = reader["dateAdded"];
        dr["picURL"] = ResolveUrl("~/images/" + reader["picURL"]);
        dt.Rows.Add(dr);
        GridView1.DataSource = dt;
        GridView1.DataBind();

    }

}

protected void Gridview1_RowCommand(object sender, GridViewCommandEventArgs e)
{


    if (e.CommandName == "removeRow")
    {
        string pic = Convert.ToString(e.CommandArgument);
        deleteCart(pic);       
    }

}


private void deleteCart(string orderID)

{

    SqlConnection con = new SqlConnection("connectionstring1");
    string str;
   str = "delete from orders where orderID='" + orderID + "'";

    con.Open();
    SqlCommand cmd = new SqlCommand(str, con);
    SqlDataReader dr = cmd.ExecuteReader();
    con.Close();

}

来源

<asp:GridView ID="GridView1" runat="server" AutoGenerateColumns="False" 
        CellPadding="4" ForeColor="#333333" GridLines="None"  OnRowCommand="Gridview1_RowCommand" >
        <AlternatingRowStyle BackColor="White" ForeColor="#284775" />
        <Columns>
            <asp:BoundField DataField="picID" HeaderText="pic id" />
            <asp:BoundField DataField="title" HeaderText="title" />
            <asp:BoundField DataField="price" HeaderText="price" />
            <asp:BoundField DataField="dateAdded" HeaderText="date" />
            <asp:ImageField DataImageUrlField="picURL" HeaderText="image">
            </asp:ImageField>
            <asp:ButtonField ButtonType="Button" Text="remove" CommandName="removeRow" />
        </Columns>
        <EditRowStyle BackColor="#999999" />
        <FooterStyle BackColor="#5D7B9D" Font-Bold="True" ForeColor="White" />
        <HeaderStyle BackColor="#5D7B9D" Font-Bold="True" ForeColor="White" />
        <PagerStyle BackColor="#284775" ForeColor="White" HorizontalAlign="Center" />
        <RowStyle BackColor="#F7F6F3" ForeColor="#333333" />
        <SelectedRowStyle BackColor="#E2DED6" Font-Bold="True" ForeColor="#333333" />
        <SortedAscendingCellStyle BackColor="#E9E7E2" />
        <SortedAscendingHeaderStyle BackColor="#506C8C" />
        <SortedDescendingCellStyle BackColor="#FFFDF8" />
        <SortedDescendingHeaderStyle BackColor="#6F8DAE" />
    </asp:GridView>

【问题讨论】:

  • “必须删除订单表中最后添加的行”是什么意思?您是否从数据库或客户端收到错误消息?错误信息是什么?涉及表的 DDL 是什么???
  • 抱歉没有最后添加的行,当我点击 gridview 行中的按钮时,该行必须被删除。我有两个表订单和产品,现在 gridview 显示带有订单的产品,因为我在 page_load 中编写了查询,所以要删除应该删除订单数据的行,我应该在 gridview1_rowcommand 中写什么?我只是在 cmd.executereader 行中的“=”附近收到错误语法错误,但不知道这段代码是否正确
  • If(!ispotback){} // 绑定网格时您的代码需要在此。如果您的 Id 在数据库中是整数类型,那么像 delete from orders where orderID='" + orderID + "'"; 这样比较是一种不好的方法,而您可以像 delete from orders where orderID=" + orderID; 那样进行比较
  • 您可以在命令语句后使用ExecuteNonQuery
  • 引用这个你必须做的删除这里完成插入satindersinght.blogspot.in/2012/08/…

标签: asp.net c#-4.0 gridview


【解决方案1】:

改进版的代码

对于Add/ Update/ Delete,您应该使用cmd.ExecuteNonQuery() 而不是cmd.ExecuteReader();

protected void Page_Load(object sender, EventArgs e)
{
  if (!Page.IsPostBack)
  {
     girdivewBind();
  }
}

  protected void Gridview1_RowCommand(object sender, GridViewCommandEventArgs e)
  {
     if (e.CommandName == "removeRow")
     {
        string pic = Convert.ToString(e.CommandArgument);
        deleteCart(pic);   
        girdivewBind(); // Bind your gridview again.    
      }
  }


public void deleteCart(string orderID)
{
  using (SqlConnection con = new SqlConnection(cn.ConnectionString))
   {
     using (SqlCommand cmd = new SqlCommand())
     {
        cmd.CommandText = "delete from orders where orderID=@id";
        cmd.Connection = con;
        cmd.CommandType = CommandType.StoredProcedure;
        cmd.Parameters.AddWithValue("@id", orderID);
        con.Open();
        var temp = cmd.ExecuteNonQuery();
        con.Close();
       }
   }
 }

 public void girdivewBind()
 { 
   SqlConnection con = new SqlConnection("connectionstring1");
   string str = "select * from Products INNER JOIN orders on Products.picID=orders.productID";
   SqlCommand cmd = new SqlCommand(str, con);
   con.Open();
   DataTable dt = new DataTable();
   dt.Columns.Add(new DataColumn("picID", typeof(int)));
   dt.Columns.Add(new DataColumn("title", typeof(string)));
   dt.Columns.Add(new DataColumn("price", typeof(int)));
   dt.Columns.Add(new DataColumn("dateAdded", typeof(DateTime)));
   dt.Columns.Add(new DataColumn("picURL", typeof(string)));
   SqlDataReader reader = cmd.ExecuteReader();
   while (reader.Read())
     {
        DataRow dr = dt.NewRow();
        dr["picID"] = Convert.ToInt32(reader["picID"]);
        dr["title"] = reader["title"];
        dr["price"] = Convert.ToInt32(reader["price"]);
        dr["dateAdded"] = reader["dateAdded"];
        dr["picURL"] = ResolveUrl("~/images/" + reader["picURL"]);
        dt.Rows.Add(dr);
       } reader.Close();
         con.Close();
       GridView1.DataSource = dt;
       GridView1.DataBind();
     }
  }

【讨论】:

  • @vikas:从gridview中删除记录并从sql server检查记录是否从数据库中删除??
  • 调试显示它没有在 deletecart 方法中移动,它只是停在 deleteCart(pic); girdivewBind();
  • @vikas: 你在变量string pic 中得到什么值也会给你发布html标记
  • 在我点击的行上获取 picID 的产品 id
  • @vikas:我已经回答了,你累了吗,你的 deleteCart 方法是错误的替换为我的答案,也使public 不是private 并且你的gridview绑定应该在while之外( reader.read){} 正如我在回答中提到的那样。如果您不表现出自己的努力,我将无法为您提供更多帮助
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2015-12-31
  • 1970-01-01
  • 2022-01-01
  • 1970-01-01
  • 1970-01-01
  • 2015-01-25
相关资源
最近更新 更多