gpt4 book ai didi

c# - 防止 Entity Framework 自动附加实体

转载 作者:太空狗 更新时间:2023-10-29 19:47:37 26 4
gpt4 key购买 nike

我正在使用 Entity Framework ,它使用的实体是数据库表示和业务对象。
所以这意味着一些被操纵的实体应该始终与上下文保持分离。

我成功地从数据库读取和写入数据,但更新时遇到一个小问题:
我有一个表“Stock”,它链接到一个表“Warehouse”。

目前的流程是这样的(简化了,但精神不减,字段较多):

  • 创建了一个新对象 Stock,其字段填充了一些值(日期...)
  • 当前的 Warehouse(针对整个请求从数据库中提取的对象)与 Stock 对象相关联
  • 对象被发送到 DAL 方法,该方法的工作是保存它。
  • DAL 方法检查数据库中是否已存在当天的库存项目(相同日期、仓库和相同类型)
  • 如果存在,该方法会从拉取的对象中更新体积并保存更改。
  • 否则,插入新的 Stock 对象。

这里的问题是,当我创建新的 Stock 对象并将其关联到 Warehouse 时,对象 EntityState 自动设置为“已添加”。因此,当我执行 SaveChanges() 并且 Stock 已经存在时,该行会更新并添加一个新的 Stock 行...
我想要的是让新的 Stock 对象保持分离状态,直到我自己附加它为止。我不希望它自动发生。

我找到的唯一解决方案是如果对象已经存在,则在保存之前从上下文中分离新对象。
我也可以 Detach() Warehouse 对象,但我认为这不是一个令人满意的解决方案,因为在实际情况中有更多的项目要关联,我不确定在它们上使用 Attach() 和 Detach() 是个好主意.
在这种情况下,在我自己将其“添加”到上下文之前,该对象只是一个“传输”对象,我希望它远离上下文。

关于如何保持 Stock 对象分离的任何想法?


代码(可能有点不对,凭内存写的):

Stock stk = new Stock();
stk.Date = DateTime.Now;
stk.Volume = 100; //so far stk is "Detached" and that's cool.
stk.Warehouse = CurrentWarehouse; //stk become "Added" and that's less cool.

DAL.Stock.Instance.Save(stk);

在保存()中:

var existing = (from s in Context.CurrentContext.Stock
where s.Warehouse.WarehouseId == stk.Warehouse.WarehouseId && s.Date == stk.Date && s.Type == 2
select s).FirstOfDefault();

if(existing != null)
{
existing.Volume = stk.Volume;
Context.CurrentContext.Detach(stk); //I find it a stupid workaround !!!!!!
}
else
{
Context.CurrentContext.AddToStock(stk); //what I would want to do.
}

Context.CurrentContext.SaveChanges()

最佳答案

您可能只想将 MergeOption 设置为适当的值。 NoTracking 将使一切保持分离状态,并允许您执行手动工作。可能还有其他方法可以做到这一点,但我通过将 MergeOption 设置为分离来做类似的事情。

http://msdn.microsoft.com/en-us/library/system.data.services.client.dataservicecontext.mergeoption.aspx

关于c# - 防止 Entity Framework 自动附加实体,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1771782/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com