星空网 > 软件开发 > ASP.net

DataTable循环删除行

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

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

3.循环彻底删除就要用.Rows.RemoveAt(intindex)方法,所以如果你是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的下面往上查找删除,这样即使这行符合条件被删除了,上面的行依旧不受影响。        正确的写法如下:  

protected void deleteDataRow(int RowID,DataTable dt) {    for (int i = dt.Rows.Count - 1; i >= 0; i--)   {         if (Convert.ToInt32(dt.Rows[i]["RowID"]) == RowID)    dt.Rows.RemoveAt(i);      }  }

 




原标题:DataTable循环删除行

关键词:DataTable

*特别声明:以上内容来自于网络收集,著作权属原作者所有,如有侵权,请联系我们: admin#shaoqun.com (#换成@)。

VAT税务筹划的最佳方法:https://www.kjdsnews.com/a/1341182.html
VAT税务筹划最佳费用管理步骤:https://www.kjdsnews.com/a/1341183.html
VAT税务筹划最佳方法指南:https://www.kjdsnews.com/a/1341184.html
VAT税务筹划最佳方法与方法:https://www.kjdsnews.com/a/1341185.html
VAT税务筹划如何算出最佳结果:https://www.kjdsnews.com/a/1341186.html
VAT税务筹划如何正确计算税收:https://www.kjdsnews.com/a/1341187.html
TEMU亚马逊美国站ASTMF3186-17、16CFR1270成人活动床栏安全要求:https://www.kjdsnews.com/a/1836339.html
一线丨访曹县产业带,看中国传统服饰出海如何杀出一个春天?:https://www.kjdsnews.com/a/1836340.html
相关文章
我的浏览记录
最新相关资讯
海外公司注册 | 跨境电商服务平台 | 深圳旅行社 | 东南亚物流