2

我试图弄清楚如何在 Azure AppFabric 缓存中缓存 EF 查询结果。目前我正在使用 LoreSoft EntityFramework 扩展来处理缓存(http://bit.ly/LWSywm)。它与内存缓存完美配合,但与跨多个 VM 的 AppFabric 配合得并不好。问题是我的 EF 对象中有虚拟属性,它们被序列化为动态代理对象,当然不能在不同的 VM 上反序列化,甚至在单个 VM 重新启动应用程序之后也不能反序列化。

我只有几个需要缓存的查询,所以我不想在整个项目中手动加载每个相关的对象。有什么方法可以序列化具有虚拟属性的 EF 对象?在我反序列化它们之后,我不需要虚拟属性神奇地再次开始延迟加载。我尝试在序列化结果之前关闭延迟加载 DbContext,但这不起作用。我发现获得可序列化 EF 对象的唯一方法是删除所有虚拟属性。

顺便说一句,我在这里看过 Julie Lerman 的文章:http: //bit.ly/LWToZT

似乎是一个很酷的项目,但我不完全确定它会解决我无法序列化 EF 对象的问题。如果我只想在我开始的地方结束,就不想走那条路。

任何想法最受赞赏!

4

2 回答 2

4

您可以将 dbcontext(或对象上下文)配置为不使用代理对象。显然,这意味着没有更改跟踪和延迟加载。如果您不急于加载对象的导航属性,它们将只是 null 而不是对代理的引用。值得注意的是,您可以在上下文的整个生命周期中打开和关闭它,因此这不是一个全有或全无的决定。

如果您使用 DbContext,则语法为:

context.Configuration.ProxyCreationEnabled = false;
于 2012-07-01T00:44:07.373 回答
1

我们也遇到过类似的问题。我们有一个服务,它返回使用 EF 从数据库中读取的数据。这些数据需要缓存在 Appfabric 中。

在我们的例子中,服务返回 DTO 对象,所以我们将 EF 对象映射到 DTO 对象,然后将 DTO 对象存储在 Appfabric 缓存中。

于 2012-06-30T21:14:49.633 回答