Datatable删除行的Delete和Remove…
来源:互联网 发布:数值最优化 高立 pdf 编辑:程序博客网 时间:2024/05/01 07:34
Datatable删除行的Delete和Remove方法比较
在C#中,如果要删除DataTable中的某一行,大约有以下几种办法:
1,使用DataTable.Rows.Remove(DataRow),或者DataTable.Rows.RemoveAt(index);可以直接删除行
2,datatable.Rows[i].Delete()。Delete()之后需要datatable.AccepteChanges()方法确认完全删除,因为Delete()只是将相应列的状态标志为删除,还可以通过datatable.RejectChanges()回滚,使该行取消删除。
在删除DataTable中的行的时候,每删除一行,DataTable中所有行的索引都会发生改变。在循环删除DataTable.Row的时候不能使用foreach。使用foreach进行循环的时候,是不允许Table有删除和添加操作的。
如果是按某列为条件进行删除,则每删完一行,整个Table的index就会立即发生变化,等于Table已经变成了一个新的表。但是索引却已经加1了。于是会造成第一列永远匹配不到。因此,每删除完一行,要跟着判断第一行是否满足删除条件。
如果要删除DataTable中的多行,应该采用倒序循环DataTable.Rows。因为正序删除时索引会发生变化。程式发生异常,很难预料后果。
for (int i = dt.Rows.Count - 1; i>= 0; i--)
{
总结:
delete和remove
Delete的使用是datatable.Rows[i].Delete();
Remove的使用是datatable.Rows.Remove(datatable.Rows[i]);
这两个的区别是,使用delete后,只是该行被标记为deleted,但是还存在,用Rows.Count来获取行数时,还是删除之前的行数.需要使用datatable.AcceptChanges()方法来提交修改.
而Remove方法则是直接删除.
如果在for循环里删除行的话,最好是使用delete方法,不然会出现count变化的情况.循环完后再使用AcceptChanges()方法提交修改,删除掉标记为deleted的行
- Datatable删除行的Delete和Remove…
- Datatable删除行的Delete和Remove方法
- Datatable删除行的Delete和Remove方法
- Datatable删除行的Delete和Remove方法
- Datatable删除行的Delete和Remove方法介绍
- Datatable删除行的Delete和Remove方法
- Datatable删除行的Delete和Remove方法的区别介绍
- Datatable删除行的Delete和Remove方法的区别介绍
- datatable 中Remove和delete的区别
- 对DataTable执行delete和remove的区别
- datatable.Rows[i].Delete()删除行
- JPA delete remove 时 上级的Collection 不删除
- 关于Datatable删除行和删除列
- numpy的delete删除数组整行和整列
- DataRow的Delete,Remove,RemoveAt方法的用法和区别
- DataRow的Delete,Remove,RemoveAt方法的用法和区别。
- Table.Rows.Remove(dr)和Table.Delete()的区别
- Table.Rows.Remove(dr)和Table.Delete()的区别
- Request.QueryString获取get方法提交的数据
- Get和Post的用法,Request.QuerySt…
- OpenCV Maching Learning 之K-Nearest Neighbors
- javascript:void(0)的用法讲…
- Android使用Intent启动Service的Intent必须是显式的
- Datatable删除行的Delete和Remove…
- 百度地图中添加动态热力图
- Asp.Net前台调用后台变量的方法
- SQL语句快速参考
- jquery中attr()和prop()的区别
- Dojo与jQuery的比较
- javascript中的闭包以及dojo中的dojo.hitch()
- SQL2008升级SQL2008R2完全教程
- 世界坐标系和相机坐标系,图像坐标系的关系