0

这里有一个棘手的问题:我有一个由 Access 表填充的 DataGrid (DataGrid.ItemsSource)。

为用户显示其他列并在(重新)排序时保留此列中的更改的最佳做法是什么?

在我的情况下,附加列是用户的 CheckBoxColumn,用于选择他想要编辑的 DataGrid 中的那些行。如果您对 DataGrid 进行排序,检查将消失。

代码:

using (OleDbConnection connection = new OleDbConnection("Provider=Microsoft.ACE.OLEDB.12.0;Data Source=" + AppDomain.CurrentDomain.BaseDirectory + "Test.accdb"))
{
    string strDbCmd = "SELECT * FROM Table1";
    OleDbDataAdapter daOleDb = new OleDbDataAdapter(strDbCmd, connection);
    DataTable dtResult = new DataTable(); // this is actually a global
    daOleDb.FillSchema(dtResult, SchemaType.Source);
    daOleDb.Fill(dtResult);
    DataGrid1.ItemsSource = dtResult.DefaultView;
    DataGridCheckBoxColumn dgCol = new DataGridCheckBoxColumn();
    DataGrid1.Columns.Insert(0, dgCol);
}

我无法更改 dtResult (实际上是全局的),因为我稍后将使用它来更新数据库:

// Later on somewhere else:
OleDbDataAdapter daOleDb = new OleDbDataAdapter(strDbCmd, connection);
// [...]
daOleDb.Update(dtResult);

现在当然我可以将所有检查存储在一个布尔数组或任何东西中,但是有没有一个聪明的解决方案可以在对 DataGrid 进行排序时保持检查设置?

亲切的问候!

4

1 回答 1

0

我想我想出了一个很好的解决方案:

填充 DataTable 后,手动添加一个 bool 列:

// [...]
daOleDb.Fill(dtResult);
DataColumn dtCol = new DataColumn("Bool", typeof(Boolean));
dtCol.DefaultValue = false;
dtResult.Columns.Add(dtCol);
dtCol.SetOrdinal(0);
DataGrid1.ItemsSource = dtResult.DefaultView;

这不会影响“RowsChanged”事件,因为它是一个添加的列,在做之前

daOleDb.Update(dtResult);

您可以简单地再次删除/删除它(不应该有任何区别,因为添加的列在被删除时也不会影响任何 ChangesEvent)

dtResult.Columns[0].Remove(); // or Columns.Delete(...)
于 2013-05-18T18:49:07.993 回答