数据库中的数据未更新,使用 C#、WPF、Entity framework 和 Visual studio 2012
Data is not updated in database, using C#,WPF, Entity framework and Visual studio 2012
这个问题参考了我这里的旧问题:Primary key in datagrid is always zero
在我之前的问题中,我正在处理具有许多关系的非常大的数据库,所以我想尝试并测试这个基本的(非常基本的)
项目。
我所做的是创建简单的基本 wpf 应用程序。添加了只有一个 table 的本地数据库,其中有两个 columns.One 是 id 列,它是主键和自动 incremented.The 其他很简单 varchar.I 添加了它作为数据源并从中创建了网格该数据源。
这是我的 xaml:
<Window
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:d="http://schemas.microsoft.com/expression/blend/2008" xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" xmlns:local="clr-namespace:WpfApplication4" mc:Ignorable="d" x:Class="WpfApplication4.MainWindow"
Title="MainWindow" Height="350" Width="525" Loaded="Window_Loaded_1">
<Window.Resources>
<CollectionViewSource x:Key="tablesViewSource" d:DesignSource="{d:DesignInstance {x:Type local:Table}, CreateList=True}"/>
</Window.Resources>
<Grid DataContext="{StaticResource tablesViewSource}">
<DataGrid x:Name="tablesDataGrid" AutoGenerateColumns="False" EnableRowVirtualization="True" ItemsSource="{Binding}" Margin="47,24,70,95" RowDetailsVisibilityMode="VisibleWhenSelected">
<DataGrid.Columns>
<DataGridTextColumn x:Name="idColumn" Binding="{Binding Id}" Header="Id" Width="SizeToHeader"/>
<DataGridTextColumn x:Name="nameColumn" Binding="{Binding name}" Header="name" Width="SizeToHeader"/>
</DataGrid.Columns>
</DataGrid>
<Button Content="Button" HorizontalAlignment="Left" Margin="221,266,0,0" VerticalAlignment="Top" Width="75" Click="Button_Click_1"/>
</Grid>
仅有的两行代码是我写的。休息是自动的 generated.Now 我想从 gridview 更新我的数据,但最大的问题是数据不是 updated.It 继续添加零。
我在这里添加了整个 cs 文件。
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows;
using System.Windows.Controls;
using System.Windows.Data;
using System.Windows.Documents;
using System.Windows.Input;
using System.Windows.Media;
using System.Windows.Media.Imaging;
using System.Windows.Navigation;
using System.Windows.Shapes;
namespace WpfApplication4
{
/// <summary>
/// Interaction logic for MainWindow.xaml
/// </summary>
public partial class MainWindow : Window
{
public MainWindow()
{
InitializeComponent();
}
private System.Data.Objects.ObjectQuery<Table> GetTablesQuery(Database1Entities database1Entities)
{
System.Data.Objects.ObjectQuery<WpfApplication4.Table> tablesQuery = database1Entities.Tables;
// Returns an ObjectQuery.
return tablesQuery;
}
private void Window_Loaded_1(object sender, RoutedEventArgs e)
{
WpfApplication4.Database1Entities database1Entities = new WpfApplication4.Database1Entities();
// Load data into Tables. You can modify this code as needed.
System.Windows.Data.CollectionViewSource tablesViewSource = ((System.Windows.Data.CollectionViewSource)(this.FindResource("tablesViewSource")));
System.Data.Objects.ObjectQuery<WpfApplication4.Table> tablesQuery = this.GetTablesQuery(database1Entities);
tablesViewSource.Source = tablesQuery.Execute(System.Data.Objects.MergeOption.AppendOnly);
}
private void Button_Click_1(object sender, RoutedEventArgs e)
{
var context = new WpfApplication4.Database1Entities();
// Database1Entities db = new Database1Entities();
// db.SaveChanges();
context.SaveChanges();
}
}
}
`
我开始怀疑自己的基础了。请帮助。
试试这个:
private void Button_Click_1(object sender, RoutedEventArgs e)
{
var context = new WpfApplication4.Database1Entities();
var table = context.Set<YourTable>();
table.Add(new YourTable { Id = id, Name = "John Doe" });
context.SaveChanges();
}
这对我有用(调整变量名称):
using System.Data.Entity;
private Database1Entities _context = new Database1Entities ();
private void Window_Loaded(object sender, RoutedEventArgs e) {
System.Windows.Data.CollectionViewSource tableViewSource = ((System.Windows.Data.CollectionViewSource)(this.FindResource("tableViewSource")));
_context.Table.Load();
tableViewSource.Source = _context.Table.Local;
}
private void Button_Click(object sender, RoutedEventArgs e) {
_context.SaveChanges();
tableDataGrid.Items.Refresh();
}
这个问题参考了我这里的旧问题:Primary key in datagrid is always zero
在我之前的问题中,我正在处理具有许多关系的非常大的数据库,所以我想尝试并测试这个基本的(非常基本的) 项目。
我所做的是创建简单的基本 wpf 应用程序。添加了只有一个 table 的本地数据库,其中有两个 columns.One 是 id 列,它是主键和自动 incremented.The 其他很简单 varchar.I 添加了它作为数据源并从中创建了网格该数据源。
这是我的 xaml:
<Window
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:d="http://schemas.microsoft.com/expression/blend/2008" xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" xmlns:local="clr-namespace:WpfApplication4" mc:Ignorable="d" x:Class="WpfApplication4.MainWindow"
Title="MainWindow" Height="350" Width="525" Loaded="Window_Loaded_1">
<Window.Resources>
<CollectionViewSource x:Key="tablesViewSource" d:DesignSource="{d:DesignInstance {x:Type local:Table}, CreateList=True}"/>
</Window.Resources>
<Grid DataContext="{StaticResource tablesViewSource}">
<DataGrid x:Name="tablesDataGrid" AutoGenerateColumns="False" EnableRowVirtualization="True" ItemsSource="{Binding}" Margin="47,24,70,95" RowDetailsVisibilityMode="VisibleWhenSelected">
<DataGrid.Columns>
<DataGridTextColumn x:Name="idColumn" Binding="{Binding Id}" Header="Id" Width="SizeToHeader"/>
<DataGridTextColumn x:Name="nameColumn" Binding="{Binding name}" Header="name" Width="SizeToHeader"/>
</DataGrid.Columns>
</DataGrid>
<Button Content="Button" HorizontalAlignment="Left" Margin="221,266,0,0" VerticalAlignment="Top" Width="75" Click="Button_Click_1"/>
</Grid>
仅有的两行代码是我写的。休息是自动的 generated.Now 我想从 gridview 更新我的数据,但最大的问题是数据不是 updated.It 继续添加零。
我在这里添加了整个 cs 文件。
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows;
using System.Windows.Controls;
using System.Windows.Data;
using System.Windows.Documents;
using System.Windows.Input;
using System.Windows.Media;
using System.Windows.Media.Imaging;
using System.Windows.Navigation;
using System.Windows.Shapes;
namespace WpfApplication4
{
/// <summary>
/// Interaction logic for MainWindow.xaml
/// </summary>
public partial class MainWindow : Window
{
public MainWindow()
{
InitializeComponent();
}
private System.Data.Objects.ObjectQuery<Table> GetTablesQuery(Database1Entities database1Entities)
{
System.Data.Objects.ObjectQuery<WpfApplication4.Table> tablesQuery = database1Entities.Tables;
// Returns an ObjectQuery.
return tablesQuery;
}
private void Window_Loaded_1(object sender, RoutedEventArgs e)
{
WpfApplication4.Database1Entities database1Entities = new WpfApplication4.Database1Entities();
// Load data into Tables. You can modify this code as needed.
System.Windows.Data.CollectionViewSource tablesViewSource = ((System.Windows.Data.CollectionViewSource)(this.FindResource("tablesViewSource")));
System.Data.Objects.ObjectQuery<WpfApplication4.Table> tablesQuery = this.GetTablesQuery(database1Entities);
tablesViewSource.Source = tablesQuery.Execute(System.Data.Objects.MergeOption.AppendOnly);
}
private void Button_Click_1(object sender, RoutedEventArgs e)
{
var context = new WpfApplication4.Database1Entities();
// Database1Entities db = new Database1Entities();
// db.SaveChanges();
context.SaveChanges();
}
}
}
`
我开始怀疑自己的基础了。请帮助。
试试这个:
private void Button_Click_1(object sender, RoutedEventArgs e)
{
var context = new WpfApplication4.Database1Entities();
var table = context.Set<YourTable>();
table.Add(new YourTable { Id = id, Name = "John Doe" });
context.SaveChanges();
}
这对我有用(调整变量名称):
using System.Data.Entity;
private Database1Entities _context = new Database1Entities ();
private void Window_Loaded(object sender, RoutedEventArgs e) {
System.Windows.Data.CollectionViewSource tableViewSource = ((System.Windows.Data.CollectionViewSource)(this.FindResource("tableViewSource")));
_context.Table.Load();
tableViewSource.Source = _context.Table.Local;
}
private void Button_Click(object sender, RoutedEventArgs e) {
_context.SaveChanges();
tableDataGrid.Items.Refresh();
}