C# DataSet.AcceptChanges 方法
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 中)):
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); } }
最后更新:2017-04-04 07:36:13
上一篇:
Sql Server 常用命令小结
下一篇:
Oracle Partition 分区详细总结
Design Pattern: Bridge 模式
??????????????????????????????????????????????????????????????????????????????????????-??????-????????????-?????????
利用virtual box 自带remote display 实现windows 远程桌面连接ubuntu
堆排序
【动手实践】Oracle 12.2 新特性:自动的列表分区创建
【速转身边开公司的朋友】连加油站都被比特币勒索病毒黑了!还没关闭服务器445端口的抓紧!
求分解后x的最小公倍数
第三届 PHP 全球开发者大会 2017·北京
JUNIT的java.lang.security安全问题以及classLoader的处理方法
计算机科学家发明阿拉伯文编程语言