1

问题简化:

我有一个带有一些数据表的数据集...我有一个绑定到其中一个数据表的 Winforms DataGrid。用户通过DataGrid将一些行粘贴到所述数据表中,比如说3行;

所有三行现在都有它们的 RowState = DataRowState.Added。

我现在开始一个 sqlserver 事务。

然后调用 dataAdapter1.Update(dataSet1) 将行更新到 SqlServer。第 1 行 .. 行 2 .. 行 3 .. sqlserver 级别的错误(按设计,我强制执行唯一索引)

检测到此错误后,我回滚 sqlserver 事务。

我还尝试使用 Dataset1.RejectChanges() 和/或 Datatable1.RejectChanges() 来“回滚”数据表/数据集的更改。

问题不是 .RejectChanges() 工作方式我设想的方式。我的数据表现在有两行(row1,row2),其 RowState = DataRowState.Unchanged; row3 完全消失了。

我想要发生的是,当我回滚 sqlserver 事务时,数据表中的所有 3 行在调用 dataAdapter1.Update() 方法之前保持在相同的状态。

(原因是用户可以查看绑定的 DataGrid 中的错误,采取纠正措施,然后再次尝试更新)。

有什么想法吗?即我正在寻找相当于在 ADO 数据表级别回滚状态的东西。

4

2 回答 2

0

好的,所以我想办法解决这个问题。

获取原始数据表的克隆,并更新克隆。

如果发生错误,您仍然拥有原始数据表及其原始 DataRowState;此外,您可以将克隆中发生的任何错误复制到原始数据表中,从而将错误反映在数据网格中供用户查看。

如果更新成功,您只需使用克隆刷新原始数据表。

VB代码:

Try
    'daMyAdapter.Update(dsDataset, "MyDatatable") <-- replace original with below lines.
    _dtMyDatatableClone = dsDataset.MyDatatable.Copy()

    If _dtMyDatatableClone IsNot Nothing Then
      daMyAdapter.Update(_dtMyDatatableClone)

       'if you get here, update was successul - refresh now!
       dsDataset.MyDatatable.Clear()
       dsDataset.MyDatatable.Merge(_dtMyDatatableClone, False, MissingSchemaAction.Ignore)
    End If
Catch
    'uh oh, put error handler here.
End Try
于 2009-08-06T06:30:14.303 回答
0

我在尝试回滚对绑定到 Xceed DataGrid 的 DataTable 的更改时遇到了类似的问题。在 DataGrid 中进行编辑后,编辑后的值都将成为 DataRow 的当前状态的一部分。RejectChanges 仅适用于防止Proposed行状态变为 Current。

为了恢复给定行的更改,我编写了一个方法来用原始版本覆盖当前行版本。为了将版本设置为Original,您只需在数据表上调用 AcceptChanges()。

    public static void RevertToOriginalValues(DataRow row)
    {
        if (row.HasVersion(DataRowVersion.Original) && row.HasVersion(DataRowVersion.Current))
        {
            for (int colIndex = 0; colIndex < row.ItemArray.Length; colIndex++)
            {
                var original = row[colIndex, DataRowVersion.Original];
                row[colIndex] = original;
            }
        }
    }
于 2012-01-27T19:13:51.443 回答