环境:.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

注:

  1. 标记删除指row.Delete(),而非dt.Rows.Remove(row),后者会将行彻底从表移除
  2. 抛异常【System.ArgumentException:该行已经属于此表(或另一个表)】
  3. 抛异常【System.Data.DeletedRowInaccessibleException:不能通过已删除的行访问该行的信息】。标记为删除的行,不止修改单元格值会引发异常,只要是访问都会,如var a = row[x]
  4. Added状态的行进行Delete后,会变成Detached(即彻底移除行),而不是Deleted,所以在进行遍历操作时要意识到可能会引发集合被修改异常:foreach (DataRow r in dt.Rows) { r.Delete(); }
  5. 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演变备忘的更多相关文章

  1. 【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 ...

  2. GIS部分理论知识备忘随笔

    文章版权由作者李晓晖和博客园共有,若转载请于明显处标明出处:http://www.cnblogs.com/naaoveGIS/ 1.高斯克吕格投影带换算 某坐标的经度为112度,其投影的6度带和3度带 ...

  3. python序列,字典备忘

    初识python备忘: 序列:列表,字符串,元组len(d),d[id],del d[id],data in d函数:cmp(x,y),len(seq),list(seq)根据字符串创建列表,max( ...

  4. Vi命令备忘

    备忘 Ctrl+u:向文件首翻半屏: Ctrl+d:向文件尾翻半屏: Ctrl+f:向文件尾翻一屏: Ctrl+b:向文件首翻一屏: Esc:从编辑模式切换到命令模式: ZZ:命令模式下保存当前文件所 ...

  5. ExtJs4常用配置方法备忘

    viewport布局常用属性 new Ext.Viewport({ layout: "border", renderTo: Ext.getBody(), defaults: { b ...

  6. [备忘] Automatically reset Windows Update components

    这两天遇到Windows 10的更新问题,官方有一个小工具,可以用来修复Windows Update的问题,备忘如下 https://support.microsoft.com/en-us/kb/97 ...

  7. ECMAScript 5(ES5)中bind方法简介备忘

    一直以来对和this有关的东西模糊不清,譬如call.apply等等.这次看到一个和bind有关的笔试题,故记此文以备忘. bind和call以及apply一样,都是可以改变上下文的this指向的.不 ...

  8. MFC通过txt查找文件并进行复制-备忘

    MFC基于对话框的Demo txt中每行一个23位的卡号. 文件夹中包含以卡号命名的图像文件.(fpt或者bmp文件) 要求遍历文件夹,找到txt中卡号所对应的图像文件,并复制出来. VC6.0写的. ...

  9. php 相关模块备忘

    在安装php的时候,不管是编译安装: ./configure --prefix=/usr/local/php --with-config-file-path=/usr/local/php/etc -- ...

随机推荐

  1. PostgreSQL 与 MySQL 相比,优势何在?

    一. PostgreSQL 的稳定性极强, Innodb 等引擎在崩溃.断电之类的灾难场景下抗打击能力有了长足进步,然而很多 MySQL 用户都遇到过Server级的数据库丢失的场景——mysql系统 ...

  2. Android知识杂记(四)

    1.完整退出activity的设计思路 1.1 封装一个基础activity类 public abstract class RootActivity extends FragmentActivity{ ...

  3. iOS开发系列--C语言之存储方式和作用域

    概述 基本上每种语言都要讨论这个话题,C语言也不例外,因为只有你完全了解每个变量或函数存储方式.作用范围和销毁时间才可能正确的使用这门语言.今天将着重介绍C语言中变量作用范围.存储方式.生命周期.作用 ...

  4. Linux 查找已安装软件的方法

    1.rpm 注意rpm区分大小写 查询已安装的以mysql开头的包 rpm  -qa mysql* 查询已安装的mysql 包 rpm -qa|grep mysql rpm的方法有时候也所有已安装的包 ...

  5. 深入浅出Alljoyn——实例分析之远程调用(Method)篇

    深入浅出就是很深入的学习了很久,还是只学了毛皮,呵呵! 服务端完整代码: #include <qcc/platform.h> #include <assert.h> #incl ...

  6. Atitit wsdl的原理attilax总结

    Atitit wsdl的原理attilax总结 1.1. 在 W3C 的 WSDL 发展史1 1.2. 获取wsdl,可能需要url后面加wsdl,也可能直接url1 1.3. Wsdl的作用2 1. ...

  7. JavaScript中闭包之浅析解读

    JavaScript中的闭包真心是一个老生常谈的问题了,最近面试也是一直问到,我自己的表述能力又不能完全支撑起来,真是抓狂.在回来的路上,我突然想到了一个很简单的事情,其实我们在做项目时候,其实就经常 ...

  8. c#设计模式-适配器模式

    一. 适配器(Adapter)模式 适配器模式把一个类的接口变换成客户端所期待的另一种接口,从而使原本接口不匹配而无法在一起工作的两个类能够在一起工作. 名称由来 这很像变压器(Adapter),变压 ...

  9. html5多出来的字自动隐藏并显示...

  10. 动态给div中新增html

    小颖最近接触的项目中用到了    innerHTML 所以小颖今天就自己做了个demo,当当当当代码请看下方: 页面效果: