环境:.net 2.0
DataRow的行状态一段时间不用就会吃不准,记录一下,备查。
DataRowState 演变表
行属于如下状态时进行右边操作→
后的状态演变
|
添加到表
dt.Rows.Add()
|
修改单元格值
row[x] = xx
|
标记删除
row.Delete()【注1】
|
提交
dt/row.AcceptChanges()
|
回滚
dt/row.RejectChanges()
|
Detached |
Added |
Detached |
Detached |
Detached【注5】 |
Detached |
Added |
-【注2】 |
Added |
Detached【注4】 |
Unchanged |
Detached |
Unchanged |
-【注2】 |
Modified |
Deleted |
Unchanged |
Unchanged |
Modified |
-【注2】 |
Modified |
Deleted |
Unchanged |
Unchanged |
Deleted |
-【注2】 |
-【注3】 |
Deleted |
Detached |
Unchanged |
注:
- 标记删除指row.Delete(),而非dt.Rows.Remove(row),后者会将行彻底从表移除
- 抛异常【System.ArgumentException:该行已经属于此表(或另一个表)】
- 抛异常【System.Data.DeletedRowInaccessibleException:不能通过已删除的行访问该行的信息】。标记为删除的行,不止修改单元格值会引发异常,只要是访问都会,如var a = row[x]
- Added状态的行进行Delete后,会变成Detached(即彻底移除行),而不是Deleted,所以在进行遍历操作时要意识到可能会引发集合被修改异常:foreach (DataRow r in dt.Rows) { r.Delete(); }
- Detached行不属于任何表,所以执行表的AcceptChanges/RejectChanges对它没意义,执行行本身的AcceptChanges则会引发异常,RejectChanges不会抛,但什么也没做
其它:
- 只有Detached行可以被添加,因为其它状态的行一定已经属于某个表(且只能属于1个表),所以添加会引发异常
- 遍历行会访问到所有非Detached状态的行,也就是Deleted的行也会被遍历到,Rows.Count同样是包含Deleted行的统计
- 执行表的AcceptChanges()后,Deleted行会被彻底移除(变为Detached),其余行变为Unchanged,原始值变为当前值
- 执行表的RejectChanges()后,Added行会被彻底移除(变为Detached),其余行变为Unchanged,当前值变回原始值
MSDN参考:https://msdn.microsoft.com/zh-cn/library/ww3k31w0(v=vs.80).aspx
- 文毕 -
【C#】DataRowState演变备忘
原文:http://www.cnblogs.com/ahdung/p/5116593.html