当删除DataSet中某个Table里的Row时,只是将该Row的RowState设置成了Deleted,如果你仔细的话,会发现Rows.Count并没有变化,我们仍然可以通过循环找到该删除的行,但找到后,却不能访问该行保存的信息(比如ID字段),因为我们要取到这个假删的ID,然后通过ADO实现真正删除数据库记录.
我用如下方法:
会报错:不能通过已删除的行访问该行的信息.
这让我很是郁闷,在网上查询相关资料后,终于找到原因,原来bugMgrDataSet.UserInfo.Rows[i]["ID"]默认是按bugMgrDataSet.UserInfo.Rows[i]["ID", DataRowVersion.Current]访问的,当前被删除了当然访问不到咯,于是改成bugMgrDataSet.UserInfo.Rows[i]["ID", DataRowVersion.Original],奇迹出现了,取到ID的值了,原来被删除之后,就变成"过去式"了,要用DataRowVersion.Original来取原来的值.
希望遇到同样问题的人看到这篇龊文之后能解决问题