C#利用SqlDataAdapte对DataTable进行批量数据操作,可以让我们大大简化操作数据的代码量,我们几乎不需要循环和不关心用户到底是新增还是修改,更不用编写新增和修改以及删除的SQL语句,适配器都帮我们在后台进行了很好的处理.
如果您要通过 SQL Server 存储过程使用 DataAdapter 来编辑或删除数据,请确保不要在存储过程定义中使用 SET NOCOUNT ON。这将使返回的受影响的行数为零,DataAdapter 会将其解释为并发冲突。在许多情况下,以何种顺序向数据源发送通过 DataSet 所做的更改是非常重要的。例如,如果更新了现有行的主键值,并且添加了以新主键值作为外键的新行,则务必要在处理插入之前处理更新。可以使用 DataTable 的 Select 方法来返回仅引用具有特定 RowState 的 DataRow 数组。然后可以将返回的 DataRow 数组传递给 DataAdapter 的 Update 方法来处理已修改的行。通过指定要更新的行的子集,可以控制处理插入、更新和删除的顺序。以下代码确保首先处理表中已删除的行,然后处理已更新的行,然后处理已插入的行。
1 DataTable table = dataSet.Tables["Customers"]; 2 //第一步处理删除. 3 adapter.Update(table.Select(null, null, DataViewRowState.Deleted)); 4 //接着处理更新 5 adapter.Update(table.Select(null, null, 6 DataViewRowState.ModifiedCurrent)); 7 //最后处理新增 8 adapter.Update(table.Select(null, null, DataViewRowState.Added));
注意 对 DataSet、DataTable 或 DataRow 调用 AcceptChanges 将导致 DataRow 的所有 Original 值被 DataRow 的 Current 值覆盖。如果修改了唯一标识该行的字段值,则在调用 AcceptChanges 后,Original 值将不再匹配数据源中的值。在调用 DataAdapter 的 Update 方法期间会对每一行自动调用 AcceptChanges。在调用 Update 方法期间,通过先将 DataAdapter 的 AcceptChangesDuringUpdate 属性设置为 false,或为 RowUpdated 事件创建一个事件处理程序并将 Status 设置为 SkipCurrentRow,可以保留原始值。(来自MSDN)
1 强类型数据集
数据库的表设计好后,可以用VS连接数据库,并将myUser 表拖放到数据集设计器中(重命名为dsUser),默认情况下,数据集会自动生成Fill方法,我们这里需要手动进行删除,只保留表结构即可,数据查询和操作逻辑我们进行自定义.如下图所示:
2 UI设计
新建一个窗体,编译后可以从工具栏将上一步新建的dsUser强类型数据集拖放到窗体上,另外添加一个BindingSource控件(主要用于对DataGridView中的数据库和DataSet的数据进行绑定)
BindingSource中选择数据源DataSource为dsUser,然后选择数据集中的一个表myUser进行绑定:
设置DataGridView的数据源为bindingSource,这样通过bindingSource1就实现了DataGridView和dsUser的数据绑定,也就是说在界面DataGridView上进行操作,可以同步到dsUser中(会在每行上打上标志)