C# DataSet.AcceptChanges 方法
2014-03-03 18:58
363 查看
DataSet.AcceptChanges 方法:
提交自加载此 DataSet 或上次调用 AcceptChanges 以来对其进行的所有更改。
DataRow 和 DataTable 类都具有 AcceptChanges 方法。 在 DataTable 级别调用 AcceptChanges,会为要调用的每个 DataRow 调用 AcceptChanges 方法。 同样,对 DataSet 调用 AcceptChanges 会导致对 DataSet 中的每个表调用 AcceptChanges。 照这样,您可在多个级别上调用该方法。 调用 DataSet 的 AcceptChanges 将使您只需调用一次,即可对所有次级对象(例如表和行)调用该方法。
当对 DataSet 调用 AcceptChanges 时,任何仍处于编辑模式的 DataRow 对象都将成功结束其编辑。 每个 DataRow 的 RowState 属性也都更改;Added 和 Modified 行变为 Unchanged,Deleted 行被移除。
如果 DataSet 包含 ForeignKeyConstraint 对象,则调用 AcceptChanges 方法还将导致强制实施 AcceptRejectRule。
代码如下(程序集:System.Data(在 system.data.dll 中)):
提交自加载此 DataSet 或上次调用 AcceptChanges 以来对其进行的所有更改。
DataRow 和 DataTable 类都具有 AcceptChanges 方法。 在 DataTable 级别调用 AcceptChanges,会为要调用的每个 DataRow 调用 AcceptChanges 方法。 同样,对 DataSet 调用 AcceptChanges 会导致对 DataSet 中的每个表调用 AcceptChanges。 照这样,您可在多个级别上调用该方法。 调用 DataSet 的 AcceptChanges 将使您只需调用一次,即可对所有次级对象(例如表和行)调用该方法。
当对 DataSet 调用 AcceptChanges 时,任何仍处于编辑模式的 DataRow 对象都将成功结束其编辑。 每个 DataRow 的 RowState 属性也都更改;Added 和 Modified 行变为 Unchanged,Deleted 行被移除。
如果 DataSet 包含 ForeignKeyConstraint 对象,则调用 AcceptChanges 方法还将导致强制实施 AcceptRejectRule。
代码如下(程序集:System.Data(在 system.data.dll 中)):
public void AcceptChanges() { IntPtr intPtr; Bid.ScopeEnter(out intPtr, "<ds.DataRow.AcceptChanges|API> %d#\n", this.ObjectID); try { this.EndEdit(); if (this.RowState != DataRowState.Detached && this.RowState != DataRowState.Deleted && this._columns.ColumnsImplementingIChangeTrackingCount > 0) { DataColumn[] columnsImplementingIChangeTracking = this._columns.ColumnsImplementingIChangeTracking; for (int i = 0; i < columnsImplementingIChangeTracking.Length; i++) { DataColumn column = columnsImplementingIChangeTracking[i]; object obj = this[column]; if (DBNull.Value != obj) { IChangeTracking changeTracking = (IChangeTracking)obj; if (changeTracking.IsChanged) { changeTracking.AcceptChanges(); } } } } this._table.CommitRow(this); } finally { Bid.ScopeLeave(ref intPtr); } }
相关文章推荐
- CVS服务器建立和权限配置方法
- Oracle10g启动与关闭的方法
- 关于SQL安装时出现的有程序安装挂起问题的解决方法
- 关于asp.net Ajax v1.0.61025版(即1.0 rc) 错误:'sys'未定义解决方法.
- oracle自增问题(两种方法)!
- SQL Server各种日期计算方法
- Photoshop CS2 9.0注册机和注册方法
- 三种方法实现实时切换CSS样式
- Asp.net中防止用户多次登录的方法
- 这是不是同一个解决方法呀?
- Linux操作系统上安装MySQL数据库的方法
- WF TrackingService 中4个获取 TrackingProfile 方法的调用时机
- 提高网站性能的方法
- JSP中的参数传递方法
- img与容器下边界的空隙(缝隙) 的解决方法
- 方法
- 设计模式读书笔记之模版方法模式(Template)
- 目前发现的最佳切洋葱不刺激眼睛的方法
- ASP.NET中输出JS的两种方法
- Linux下安装软件的两种方法