2

我有一个 Recommendation 对象和一个 FeedbackLevel 对象,FeedbackLevel 对象是 Recommendation 对象内的导航属性

推荐 int EntityKey; 反馈级别;

使用 AddObject() 插入一个新的就可以了。这是我正在尝试更新的内容,但它不起作用。

recommendation.Level = myRepository.GetFeedbackLevel(newLevel);
_context.Recommendations.Attach(new Recommendation { EntityKey = recommendation.EntityKey });
_context.Recommendations.ApplyCurrentValues(recommendation);
_context.SaveChanges(System.Data.Objects.SaveOptions.AcceptAllChangesAfterSave);

上面的代码基本上是我所拥有的压缩版本。更新标量属性工作得很好,但我无法更新新的导航属性,因为 avove 代码在没有任何更改的情况下成功!

我还尝试了其他一些方法,例如先获取现有的 Recommendation,然后再将 FeedbackLevel 重新分配给它,但没有任何运气。

更新:

这是我在保存调用期间从 sql 分析器捕获的内容:

exec sp_executesql N'update [dbo].[Recommendation]
set [FeedbackComment] = @0, [LastUpdatedDate] = @1
where ([RecommendationKey] = @2)
',N'@0 varchar(255),@1 datetime,@2 int',@0='This is cool',@1='2010-01-08 10:06:06.5400000',@2=11

看起来它甚至不知道需要保存 FeedbackLevel。我怎样才能让它触发它?

4

1 回答 1

0

不确定您在这里尝试做什么,但是如果您尝试进行更新,简单的方法是

1)做一个,GET [entityName] by id,使用include来获取任何子属性

2)更新属性

3)确保实体状态被修改

4) 保存更改

通过首先执行 GET,您无需在更新之前将其附加到上下文中,因为它已经在其中。

于 2011-11-04T04:34:53.993 回答