zoukankan      html  css  js  c++  java
  • 【C#】DataRowState演变备忘

    环境:.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行可以被添加,因为其它状态的行一定已经属于某个表(且只能属于1个表),所以添加会引发异常
    • 遍历行会访问到所有非Detached状态的行,也就是Deleted的行也会被遍历到,Rows.Count同样是包含Deleted行的统计
    • 执行表的AcceptChanges()后,Deleted行会被彻底移除(变为Detached),其余行变为Unchanged,原始值变为当前值
    • 执行表的RejectChanges()后,Added行会被彻底移除(变为Detached),其余行变为Unchanged,当前值变回原始值

    MSDN参考:https://docs.microsoft.com/en-us/dotnet/framework/data/adonet/dataset-datatable-dataview/row-states-and-row-versions

    - 文毕 -

  • 相关阅读:
    如何在Ubuntu 20.04 LTS Focal Fossa上安装Webmin
    如何在Linux服务器上创建一个具有管理权限的新用户?
    如何在Ubuntu 20.04 LTS上安装Apache Subversion
    error more than one devices and emulator
    深度学习+CRF解决NER问题
    word2vec训练&IC分词(待)
    tensorflow基础
    (转)pycharm快捷键
    Python包的相对导入时出现问题解决
    python工具使用笔记
  • 原文地址:https://www.cnblogs.com/ahdung/p/5116593.html
Copyright © 2011-2022 走看看