DataTable.AcceptChanges方法有何用处

提交自上次调用 AcceptChanges 以来对该表进行的全部更改。

调用 AcceptChanges 后,再用 DataAdapter.Update() 不会有不论什么新数据被更新到数据库中。那……那它有什么用处呢?

曾经的做法:

Fill –> Edit –>Update –> 又一次Fill –> Edit –> Update –> ……

“更新了数据当然要又一次获取啦!”,再次更新后,再再次又一次获取。

如今的做法:

Fill –> Edit –> Update –> AcceptChanges –> Edit –> Update –> AcceptChanges –> Edit –> Update –> ……

開始获取一次就好了,反正你更新了数据后再获取的不就是你刚才更新的吗,干嘛还要获取一遍呢?

AcceptChanges 在 Update 后 !

-----------------------------------------丑陋切割线-------------------------------------------------------------

AcceptChanges()和RejectChanges() http://www.cnblogs.com/perfect/archive/2007/08/06/844634.html

近期在园子里看了几篇相关的文章,总结了一下(还请多多指正):

Delete()是面向对象状态操作的(能够回滚);RemoveAt()是面向普通集合操作的(不能够回滚,等价于先Delete()后AcceptChanges())

DataTable.AcceptChanges方法

提交自上次调用 AcceptChanges 以来对该表进行的全部更改。调用 AcceptChanges 时,不论什么仍处于编辑模式的 DataRow 对象将成功结束其编辑。DataRowState 也会随之更改:全部状态为 Added 和 Modified 的行的状态都变为 Unchanged;状态为 Deleted 的行则被移除。

在您尝试使用 DbDataAdapter.Update 方法更新 DataSet 之后,一般会对 DataTable 调用 AcceptChanges 方法。 DataTable.RejectChanges方法

回滚自该表载入以来或上次调用 AcceptChanges 以来对该表进行的全部更改。

调用 RejectChanges 时,不论什么仍处于编辑模式的 DataRow 对象将取消其编辑。新行被移除。DataRowState 设置为 Modified 或 Deleted 的行返回到其初始状态。 使用 Delete 方法后,RowState 变成“已删除”。在您调用 AcceptChanges 之前,它一直保持“已删除”。可通过调用 RejectChanges 取消删除行。 而RemoveAt表示当移除行时,该行中的全部数据都将丢失。您还能够调用 DataRow 类的 Delete 方法来标记某行以供移除。调用
RemoveAt 等同于先调用 Delete 再调用 AcceptChanges。 也就是说使用Delete()方法删除行后是能够回滚的,而使用RemoveAt(int)方法是不能回滚的。 总结:

1、Delete()之前接收了AcceptChanges()后,都仅仅加上删除标记,以后再次接受了AcceptChanges()后才真正删除,否则没有再次接受AcceptChanges()遇到RejectChanges()能够回滚

2、Delete()之前没有接收AcceptChanges(),之后马上接受AcceptChanges(),也真正删除

3、Delete()之前没有接收AcceptChanges(),之后也没马上接受AcceptChanges(),会彻底删除:由于没有必要回滚

时间: 2024-10-06 18:25:29

DataTable.AcceptChanges方法有何用处的相关文章

C#DataTable使用方法详解

在项目中常常常使用到DataTable,假设DataTable使用得当,不仅能使程序简洁有用,并且可以提高性能,达到事半功倍的效果,现对DataTable的使用技巧进行一下总结. 1.添加引用 1 using System.Data; 2.创建表 1 2 3 4 //创建一个空表 DataTable dt = new DataTable(); //创建一个名为"Table_New"的空表 DataTable dt = new DataTable("Table_New"

DataTable.AcceptChanges的理解

OleDbDataAdapter 怎么更新不了数据库? String    tbName    =    ds.Tables[0].TableName; String    tem    =    ds.Tables[0].Rows[0]["BOMID"].ToString(); DataRow    dr    =    ds.Tables[0].NewRow(); dr["BOMID"]    =    "104"; dr["Qua

C#实现将json转换为DataTable的方法

本文实例讲述了C#实现将json转换为DataTable的方法.分享给大家供大家参考.具体实现方法如下: 代码如下: #region 将json转换为DataTable /// <summary> /// 将json转换为DataTable /// </summary> /// <param name="strJson">得到的json</param> /// <returns></returns> private

[转]dataTable select() 方法

DataTable是我们在进行开发时经常用到的一个类,并且经常需要对DataTable中的数据进行筛选等操作,下面就介绍一下Datatable中经常用到的一个方法——Select,微软提供了四个函数的重载,分别是 Select() Select(string filterExpression) Select(string filterExpression, string sort) Select(string filterExpression,string sort, DataViewRowSt

DataTable扩展方法ToList&lt;T&gt;()、ToJSON()、ToArrayList()

/// <summary> /// 扩展方法类 /// </summary> public static class CommonExtension { /// <summary> /// 数据类型对应转换方法字典 /// </summary> static Dictionary<Type, Func<object, object>> dic_convert = new Dictionary<Type, Func<obje

mvc的视图中显示DataTable的方法

mvc的视图中显示DataTable的方法: 不断的循环画出table @{ ViewBag.Title = "ShowDataTable"; } @using System.Data; @model Models.ConModel @{ var table = Model.ExcelTable as DataTable; } <script src="~/Scripts/My97DatePicker/WdatePicker.js"></scrip

反射 DataTable拓展方法 转实体对象、实体集合、JSON

Mapper类 using System; using System.Collections.Generic; using System.Data; using System.Globalization; using System.Linq; using System.Reflection; using System.Text; using System.Threading.Tasks; namespace CommonHelper { public class Mapper { public

datatable数据类型方法

Datatable数据类型介绍 简介: 这里介绍个在开发中经常用到的数据类型,数据类型为datatable.从数据库中查出的数据存放在datatable,但是很多情况下需要对查出的数据处理,这就需要积累些datatable方法,这样开发会更快. 方法介绍 用法一.声明一个datatable类型 通过声明自己创建一个datatable类型,并填充数据 DataTable dt = newDataTable(); dt.Columns.Add("Username"); dt.Columns

List转Datatable 新方法

方法1,最简单的转换 DataTable dt = new DataTable(); dt.Columns.Add("id"); dt.Columns.Add("name"); dt.Rows.Add(new object[]{ 0,"顶层菜单"}); foreach (var cm in comdList) { DataRow dr = dt.NewRow(); dr["id"] = cm.SYS_COMMANDS_ID;