1

我正在尝试将 EF4 作为 .Net 4.0 WCF 服务的一部分。该服务的目的是将文档数据作为实体对象数组返回给我们的任何 ASP.Net 应用程序。这些应用程序仍在 .Net 2.0 中。由于解决方案的性质,我在上下文级别禁用了 LazyLoading。我从这个开始:

var revQuery = from revs in context.tbl_Document_Revision
                       where (revs.ID == myIDVar)
                       select revs;

一切正常,我收到正确数量的填充对象。但是,当我在查询中添加一个 Include 以允许我们从具有定义导航的相关表中提取字段时,只有第一条记录会完全填充到调用应用程序中:

var revQuery = from revs in context.tbl_Document_Revision.Include("tbl_Staff")
                       where (revs.ID == myIDVar)
                       select revs;

该数组的大小正确,但第一个元素之后的所有元素都是空白的默认占位符。就像使用 Include 已经恢复到 LazyLoading 一样,我似乎无法将它踢到线上。还有其他人有这个问题吗?

4

2 回答 2

0

尝试显式加载属性,而不是使用 include 方法。无法告诉您为什么 include 方法不起作用。

    var revQuery = from revs in context.tbl_Document_Revision
                   where (revs.ID == myIDVar)
                   select revs;
    foreach(var rev in revQuery)
    {
    context.LoadProperty(rev, "tbl_staff");
    }

要尝试的另一件事是使用 lamda 而不是查询语法,看看是否有帮助。

    var revQuery = context.tblDocument_Revision.Include("tbl_staff")
    .Where( tbl => tbl.ID == myIDVar)
于 2011-08-07T06:47:00.057 回答
0

在回到这个问题来尝试杰克的建议时,我找到了一个可能的答案。当我遇到最初的问题时,我仍在开发中,并在我的开发 PC 上托管服务和应用程序。在解决它之后,我部署了 WCF 服务的测试版本。

当我去测试上面建议的更改时,我的应用程序仍然指向有效的服务测试实例(与去年相比没有变化)!因此,只有当您在同一台机器上拥有服务和调用应用程序时,才会出现问题。我会把原因留给更聪明的人!:-)

于 2011-08-16T14:08:01.700 回答