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的處理方法
計算機科學家發明阿拉伯文編程語言