我有简单的查询,将两个表中的数据加载到GUI中.我将加载的数据保存到广泛可用的对象客户端currentSelectedClient.using (var context = new EntityBazaCRM()) {currentlySelectedClient = context.Kliencis.Include(...

我有简单的查询,将两个表中的数据加载到GUI中.我将加载的数据保存到广泛可用的对象客户端currentSelectedClient.
using (var context = new EntityBazaCRM())
{
currentlySelectedClient = context.Kliencis.Include("Podmioty").FirstOrDefault(d => d.KlienciID == klientId);
if (currentlySelectedClient != null)
{
textImie.Text = currentlySelectedClient.Podmioty.PodmiotOsobaImie;
textNazwisko.Text = currentlySelectedClient.Podmioty.PodmiotOsobaNazwisko;
}
else
{
textNazwa.Text = currentlySelectedClient.Podmioty.PodmiotFirmaNazwa;
}
}
所以现在如果我想:
1)保存用户所做的更改我该怎么做?我是否必须在数据库方面准备一些东西?如何处理修改多个表(某些数据在这里,有些数据在那里)?我现在的代码好像写了.KlienciHaslo就好了,但它根本不影响Podmioty.我尝试了不同的组合,但没有运气.
2)将新客户端添加到数据库(并将信息保存到相关表)?
currentClient.Podmioty.PodmiotOsobaImie = textImie.Text; // not saved
currentClient.Podmioty.PodmiotOsobaNazwisko = textNazwisko.Text; // not saved
currentClient.KlienciHaslo = "TEST111"; // saved
using (var context = new EntityBazaCRM())
{
var objectInDB = context.Kliencis.SingleOrDefault(t => t.KlienciID == currentClient.KlienciID);
if (objectInDB != null)
{
// context.ObjectStateManager.ChangeObjectState(currentClient.Podmioty, EntityState.Modified);
//context.Podmioties.Attach(currentClient.Podmioty);
context.Kliencis.ApplyCurrentValues(currentClient); // update current client
//context.ApplyCurrentValues("Podmioty", currentClient.Podmioty); // update current client
}
else
{
context.Kliencis.AddObject(currentClient); // save new Client
}
context.SaveChanges();
}
我如何实现这两个目标?
编辑答案(不保存任何内容):
currentClient.Podmioty.PodmiotOsobaImie = textImie.Text; // no save
currentClient.Podmioty.PodmiotOsobaNazwisko = textNazwisko.Text; // no save
currentClient.KlienciHaslo = "TEST1134"; // no save
using (var context = new EntityBazaCRM())
{
if (context.Kliencis.Any(t => t.KlienciID == currentClient.KlienciID))
{
context.Kliencis.Attach(currentClient); // update current client
}
else
{
context.Kliencis.AddObject(currentClient); // save new Client
}
context.SaveChanges();
}
解决方法:
显然ApplyCurrentValues仅适用于标量属性.
如果你附加了currentClient,那么关联的对象也应该附加,这意味着当你SaveChanges()时它们会被更新
但是,您将获得一个具有密钥存在异常的Object,因为您已经将对象从数据库加载到objectInDB变量中.上下文只能包含一个Entity的副本,并且它知道currentClient与objectInDB相同,因此抛出异常.
请尝试使用此模式
if (context.Kliencis.Any(t => t.KlienciID == currentClient.KlienciID))
{
context.Kliencis.Attach(currentClient); // update current client
}
else
{
context.Kliencis.AddObject(currentClient); // save new Client
}
或者,如果您使用身份作为ID,那么
// if the ID is != 0 then it's an existing database record
if (currentClient.KlienciID != 0)
{
context.Kliencis.Attach(currentClient); // update current client
}
else // the ID is 0; it's a new record
{
context.Kliencis.AddObject(currentClient); // save new Client
}
本文标题为:c# – 使用实体框架将更改保存回数据库


基础教程推荐
- c#多线程之间的排他锁的实现 2023-04-27
- C#使用TextBox作数据输入方法 2023-04-21
- C#中的反射(System.Reflection) 2023-06-07
- C#写差异文件备份工具的示例 2023-03-13
- 基于WPF实现一个简单的音频播放动画控件 2023-06-27
- C#实现数独解法 2023-06-15
- c# delegate和event的使用说明 2023-04-09
- C# 三种方式实现Socket数据接收 2023-05-05
- 详解C#对路径...的访问被拒绝解决过程 2023-03-28
- C#多线程Thread使用示例详解 2023-04-21