C#中DataTable删除行的方法分析
本文实例讲述了C#中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删除行,实例代码如下:
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();
感兴趣的朋友可以测试运行本文实例以加深理解,希望本文所述对大家C#程序设计的学习有所帮助。
- C#使用DataSet Datatable更新数据库的三种实现方法
- C#中DataTable排序、检索、合并等操作实例
- C#中把Datatable转换为Json的5个代码实例
- C#对DataTable里数据排序的方法
- c#将list类型转换成DataTable方法示例
- C#中datatable去重的方法
- C#将DataTable转换成list的方法
- C#从DataTable获取数据的方法
- C#实现将DataTable内容输出到Excel表格的方法
- c#中合并DataTable重复行的值
- C#中csv文件与DataTable互相导入处理实例解析
- C# DataTable中Compute方法用法集锦(数值/字符串/运算符/表等操作)
相关文章
C#设计模式之Builder生成器模式解决带老婆配置电脑问题实例
这篇文章主要介绍了C#设计模式之Builder生成器模式解决带老婆配置电脑问题,简单介绍了生成器模式的概念、功能并结合具体实例形式分析了C#生成器模式解决配电脑问题的步骤与相关操作技巧,需要的朋友可以参考下2017-09-09c# 给button添加不规则的图片以及用pictureBox替代button响应点击事件的方法
这篇文章介绍了c# 给button添加不规则的图片以及用pictureBox替代button响应点击事件的方法,有需要的朋友可以参考一下2013-09-09
最新评论