【C#】DataRowState演变备忘
2016-01-09 15:49
597 查看
环境:.net 2.0
DataRow的行状态一段时间不用就会吃不准,记录一下,备查。
DataRowState 演变表
注:
标记删除指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
- 文毕 -
DataRow的行状态一段时间不用就会吃不准,记录一下,备查。
行属于如下状态时进行右边操作→ 后的状态演变 | 添加到表 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#中线程同步
- c#中的引用类型和值类型
- C# winform 动态添加控件之GroupBox和TextBox
- .Net中C#的DllImport的用法
- C#的Socket实现UDP协议通信
- C# udpclient 发送数据断网后自动连接的方法
- c# textbox显示文本获取行数
- C# socket编程实践——简单聊天室
- C#学习笔记-进制转换
- C#全局键盘监听
- C# 对话框类(OpenFileDialog,SaveFileDialog,FolderBrowserDialog)
- C#通过SC命令和静态公共类来操作Windows服务
- C#创建Window服务图解,安装、配置、以及C#操作Windows服务
- C# 继承 和 组合
- C#操作目录和文件
- c#中绝对路径和相对路径
- C#Winform程序如何发布并自动升级(图解)
- c#汉字转为拼音
- c#.net调用pdf2swf.exe将pdf文件转换为swf,vs中运行正常,布署IIS服务器部署转换后文字部分为空白
- 享元模式 c#