【C#】DataRowState演变备忘
环境:.net 2.0
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行可以被添加,因为其它状态的行一定已经属于某个表(且只能属于个表),所以添加会引发异常
- 遍历行会访问到所有非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演变备忘的更多相关文章
- 【C#】无损转换Image为Icon 【C#】组件发布:MessageTip,轻快型消息提示窗 【C#】给无窗口的进程发送消息 【手记】WebBrowser响应页面中的blank开新窗口及window.close关闭本窗体 【手记】调用Process.EnterDebugMode引发异常:并非所有引用的特权或组都分配给呼叫方 【C#】DataRowState演变备忘
[C#]无损转换Image为Icon 如题,市面上常见的方法是: var handle = bmp.GetHicon(); //得到图标句柄 return Icon.FromHandle(handle ...
- GIS部分理论知识备忘随笔
文章版权由作者李晓晖和博客园共有,若转载请于明显处标明出处:http://www.cnblogs.com/naaoveGIS/ 1.高斯克吕格投影带换算 某坐标的经度为112度,其投影的6度带和3度带 ...
- python序列,字典备忘
初识python备忘: 序列:列表,字符串,元组len(d),d[id],del d[id],data in d函数:cmp(x,y),len(seq),list(seq)根据字符串创建列表,max( ...
- Vi命令备忘
备忘 Ctrl+u:向文件首翻半屏: Ctrl+d:向文件尾翻半屏: Ctrl+f:向文件尾翻一屏: Ctrl+b:向文件首翻一屏: Esc:从编辑模式切换到命令模式: ZZ:命令模式下保存当前文件所 ...
- ExtJs4常用配置方法备忘
viewport布局常用属性 new Ext.Viewport({ layout: "border", renderTo: Ext.getBody(), defaults: { b ...
- [备忘] Automatically reset Windows Update components
这两天遇到Windows 10的更新问题,官方有一个小工具,可以用来修复Windows Update的问题,备忘如下 https://support.microsoft.com/en-us/kb/97 ...
- ECMAScript 5(ES5)中bind方法简介备忘
一直以来对和this有关的东西模糊不清,譬如call.apply等等.这次看到一个和bind有关的笔试题,故记此文以备忘. bind和call以及apply一样,都是可以改变上下文的this指向的.不 ...
- MFC通过txt查找文件并进行复制-备忘
MFC基于对话框的Demo txt中每行一个23位的卡号. 文件夹中包含以卡号命名的图像文件.(fpt或者bmp文件) 要求遍历文件夹,找到txt中卡号所对应的图像文件,并复制出来. VC6.0写的. ...
- php 相关模块备忘
在安装php的时候,不管是编译安装: ./configure --prefix=/usr/local/php --with-config-file-path=/usr/local/php/etc -- ...
随机推荐
- Logging with NLog
相比较log4net, 我更喜欢NLog, 因为NLog 更简单, 而且配置选项也更加的清楚,可能是因为log4net 是从log4j 移植过来的一个原因吧,总感觉有很多的java 成分在. 要使用N ...
- 掀起你的盖头来:Unit Of Work-工作单元
写在前面 阅读目录: 概念中的理解 代码中的实现 后记 掀起了你的盖头来,让我看你的眼睛,你的眼睛明又亮呀,好像那水波一模样:掀起了你的盖头来,让我看你的脸儿,看看你的脸儿红又圆呀,好像那苹果到秋天. ...
- [译]Asp.net MVC 之 Contorllers(一)
Asp.net MVC contorllers 在Ajax全面开花的时代,ASP.NET Web Forms 开始慢慢变得落后.有人说,Ajax已经给了Asp.net致命一击.Ajax使越来越多的控制 ...
- Atitit.数据索引 的种类以及原理实现机制 索引常用的存储结构
Atitit.数据索引 的种类以及原理实现机制 索引常用的存储结构 1. 索引的分类1 1.1. 按照存储结构划分btree,hash,bitmap,fulltext1 1.2. 索引的类型 按查找 ...
- Java Web应用的开发环境配置
1:第一是下载好Eclipse开发工具,这里不做叙述,自行下载安装. 2:使用Eclipse开发WEB项目,启动Eclipse,选择File--->new --->other---> ...
- SQL Server 解读【已分区索引的特殊指导原则】(1)- 索引对齐
一.前言 在MSDN上看到一篇关于SQL Server 表分区的文档:已分区索引的特殊指导原则,如果你对表分区没有实战经验的话是比较难理解文档里面描述的意思.这里我就里面的一些概念进行讲解,方便大家的 ...
- Sql Server系列:数据库组成及系统数据库
1. 数据库组成 数据库的存储结构分为逻辑存储结构和物理存储结构. ◊ 逻辑存储结构:说明数据库是由哪些性质的信息所组成.SQL Server的数据库不仅仅只是数据的存储,所有与数据处理操作相关的信息 ...
- 字典 Key值转换为数组
public static string[] GetCategories() { Dictionary<string, int> itemMap = new Dictionary<s ...
- 深入理解脚本化CSS系列第一篇——脚本化行内样式
× 目录 [1]用法 [2]属性 [3]方法 前面的话 脚本化CSS,通俗点说,就是使用javascript来操作CSS.引入CSS有3种方式:外部样式,内部样式和行间样式.本文将主要介绍脚本化行间样 ...
- 解决Oracle SQL Developer无法连接远程服务器的问题
在使用Oracle SQL Developer连接远程服务器的时候,出现如下的错误 在服务器本地是可以正常连接的.这个让人想起来,跟SQL Server的一些设计有些类似,服务器估计默认只在本地监听, ...