前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >【C#】DataRowState演变备忘

【C#】DataRowState演变备忘

作者头像
AhDung
发布2018-09-13 11:11:13
6170
发布2018-09-13 11:11:13
举报
文章被收录于专栏:AhDung

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

注:

  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://msdn.microsoft.com/zh-cn/library/ww3k31w0(v=vs.80).aspx

- 文毕 -

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2016-01-09 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档