如何使用WPF的DataGrid查看,编辑和更新数据库表?

时间:2011-05-23 23:10:27

标签: wpf visual-studio-2010 data-binding c#-4.0 wpfdatagrid

我是WPF中的新手,更多的是WPF Datagrid竞技场。我是如此习惯于与表兄一起工作 - 来自Windows Forms的DatagridView,但这是我第一次使用WPF的Datagrid Control,并且我很难过!

我使用Vidual Studio 2010中的内置数据源向导创建了一个数据集。创建此数据集后,我使用了另一个内置功能,允许我自动生成预先绑定到此表的数据网格在数据集中,我可以将它放到窗口上。

现在,所有这一切都做得很好,直到我来到我需要让用户编辑datagrid的内容的部分,并通过回调,将新的/更新的数据提交到数据库中的基础表

我已经尝试过搜索,但大多数文章都已过时,有些文章没有像我这样的新手那样有问题。

一位消息人士说:

  

DataGrid检查   IEditableCollectionView的CanAddNew,   CanCancelEdit和CanRemove   执行之前的属性   EditItem,CancelEdit或CommitEdit   方法。所以如果编辑似乎没有   因某些原因工作,一定要检查   它能够编辑。

来自an MSDN source,但Visual Studio 11的自动生成功能为数据绑定源提供了此功能

<Window.Resources>
    <my:crimexDataSet x:Key="crimexDataSet"  />
    <CollectionViewSource x:Key="datapoolViewSource" Source="{Binding Path=datapool, Source={StaticResource crimexDataSet}}" />
</Window.Resources>

那么,我如何从这种数据源转移到IEditableCollectionView类数据源,以便启用编辑?提前谢谢......

1 个答案:

答案 0 :(得分:1)

如果这不是一个寿命很短的应用程序,我会省去很多痛苦并了解MVVM(Model-View-ViewModel)模式。这是WPF和Silverlight世界中非常常见的模式。

基本上,您可以创建一个专门设计为网格数据源的类,以及您在窗口中可能需要的其他数据。

对于这个特殊需求,您可能会使用ObservableCollection作为绑定到网格的属性的类型。

在StackOverflow上有很多关于MVVM的信息,可以在谷歌和书籍中找到。如果您了解模式,它可以真正减少UI开发体验。