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#程序设计的学习有所帮助。