【问题标题】:RIA Services query: Nested "from" and include childrenRIA 服务查询:嵌套“来自”并包含子级
【发布时间】:2010-04-02 07:03:50
【问题描述】:

我有以下schema

我想做的是从 StaffId 选择的 StaffAssignment 中检索所有客户(和子属性)。

所以我写了以下查询:

from c in ObjectContext.Customers.Include("Assignments.Activities")
               from a in c.Assignments
               from sa in a.StaffAssignments
               where sa.StaffId == staffId
               select c

但是没有加载子属性(我也在服务元数据文件中添加了 [Include])。

我做错了什么?

Gtz, 斯蒂芬。

【问题讨论】:

标签: linq wcf-ria-services


【解决方案1】:

我遇到了同样的问题。

这是我的模型(取自 NorthWind)

DomainService 看起来像:

[EnableClientAccess()]
public class DomainService1 : LinqToEntitiesDomainService<AdventureWorksLT2008Entities>
{
    public IQueryable<Customer> GetCustomer()
    {
        return this.ObjectContext.Customer.Include("CustomerAddress").Include("CustomerAddress.Address");
    }
}

我在所有导航属性上添加了 [Include] 属性:

public partial class Customer
{
    internal sealed class CustomerMetadata
    {
        // Metadata classes are not meant to be instantiated.
        private CustomerMetadata() { }

        public string CompanyName { get; set; }

        [Include]
        public EntityCollection<CustomerAddress> CustomerAddress { get; set; }


在客户端代码中,我使用了这个:

var dc = new MyDomainContext();

var query = dc.GetCustomerQuery();

var op = dc.Load(query, loadOperation =>
{
    var customer = loadOperation.Entities.FirstOrDefault();
    var address = customer.CustomerAddress.FirstOrDefault().Address;
}, null);


请注意,这仅在以下情况下有效:

  • ObjectContext 由 EntityFramework 自动生成(无自定义 Context 或 Poco 实体)
  • DomainService 是“LinqToEntitiesDomainService”

另见this link

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2011-11-20
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多