C#中DataTable删除行的方法分析

2021-04-25 07:14

阅读:437

标签:like   temp   plugin   清空   too   必须   命名规范   play   point   

本文实例讲述了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 

这个的错误在于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 

感兴趣的朋友可以测试运行本文实例以加深理解,希望本文所述对大家C#程序设计的学习有所帮助。

除声明外,跑步客文章均为原创,转载请以链接形式标明本文地址
  C#中DataTable删除行的方法分析

本文地址:  http://www.paobuke.com/develop/c-develop/pbk23491.html




相关内容

技术分享图片
C#实现百度ping推送功能的方法
技术分享图片
Windows系统中使用C#编写蓝牙通信程序的简单实例
技术分享图片
详解C#面相对象编程中的继承特性
技术分享图片
C#实现清空回收站的方法

技术分享图片
C#实现Ping的方法小结
技术分享图片
C#如何解析http报文
技术分享图片
C#的winform控件命名规范
技术分享图片
C#中String类常用方法汇总

C#中DataTable删除行的方法分析

标签:like   temp   plugin   清空   too   必须   命名规范   play   point   

原文地址:http://www.cnblogs.com/paobuke/p/7919960.html


评论


亲,登录后才可以留言!