当前位置:编程学习 > asp >>

关于DataTable删除行的问题

自己的删除例子(drTemp是表,gvSummary是dev 的gridview。单击右键点击grid删除):

1、dtTemp.Rows.RemoveAt(gvSummary.FocusedRowHandle);

2、dtTemp.Rows[gvSummary.FocusedRowHandle].Delete();  dtTemp.AcceptChanges();

在C#中,如果要删除DataTable中的某一行,大约有以下几种办法:

 1.如果只是想删除datatable中的一行,可以用DataRow的delete,但是必须要删除后让DataTable知道,所以就要用到.AcceptChanges()方法,原因是这种删除只是标识性删除,就像我们通常在数据库中用到的IsDelete字段。

Delete()之后需要datatable.AccepteChanges()方法确认完全删除,因为Delete()只是将相应列的状态标志为删除,还可以通过datatable.RejectChanges()回滚,使该行取消删除。

  2.彻底删除就要用到datatable的.Rows.Remove(DataRow dr)方法,同理也只是删除一行可以,如果要循环删除请继续往下看。

3.循环彻底删除就要用.Rows.RemoveAt(int index)方法,所以如果你是foreach的爱好者,在此请你换换口味,还有如果你是for的i++的忠实fans也希望你能换个思维。先看一下上面程序的正向写法(错误的,不可用)

   for (int i = 0, j = dt.Rows.Count; i < j; i++)
        {
            if (Convert.ToInt32(dt.Rows[i]["RowID"]) == RowID)
                dt.Rows.RemoveAt(i);
        }
 

  这个的错误在于datatable的RemoveAt()会在删除后更新dataTable的index,所以你要删除的index可能已经不是你的符合Convert.ToInt32(dt.Rows[i]["RowID"]) == RowID的index了,甚者还会抛出异常,说你访问的index不存在。

还是要慎用datatable.Rows.RemoveAt(i),若要删除多行,可以连续用Delete(),然后采用AccepteChanges()方法确认删除。


下边的例子在网上搜索到的。没有试过

使用select方法:
先把要删除的记录标记一下,然后select删除行,OK
        for (int i = 0; i < len; i++)
        {
            if (((CheckBox)Rp.Items[i].FindControl("CB")).Checked)
            {
                dt.Rows[i]["C0"] = 1;//标记要删除的记录
            }
        }
        foreach (DataRow r in dt.Select("c0=1"))
        {
            r.Delete();
        }
        Rp.DataSource = dt;
        Rp.DataBind(); 


摘自  SYZ_YUMEIZHOU_YY 
补充:Web开发 , ASP.Net ,
CopyRight © 2012 站长网 编程知识问答 www.zzzyk.com All Rights Reserved
部份技术文章来自网络,