【问题标题】: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。