父查询包括EF上的子查询

时间:2012-05-29 08:53:16

标签: c# linq mvvm silverlight-4.0 ria

我正在使用RIA Services - MVVM pattern使用C#处理Silverlight。当我尝试从OrdersOrdersDetails获取记录时,我会收到以下错误:

  

'注意'不是
的成员   'Transient.collection [XXX.SilverLight.Web.Models.OrderDetails(可空=真,默认值=)]'。
要   提取集合元素的属性,使用子查询进行迭代   在收集。近简单标识符,第6行,第58列。

这是我的问题:

public IQueryable<Order> AdvancedSearchOrder(string condition)
{
    ObjectQuery<Order> myQuery = new ObjectQuery<Order>("Orders", DbContext.ObjectContext()).Include("OrderDetails");
    if (condition != "")
    {
        myQuery = myQuery.Where(condition);
    }
    return myQuery;
}

在这种情况下,我有

condition = "( (it.CustomerName like 'test')  )  and  ( (it.OrderDetails.Notes like 'testnote') )";

当我将其设置为

condition = "( (it.CustomerName like 'test')  )";

然后,它很有效。

1 个答案:

答案 0 :(得分:0)

您正在尝试使用it.OrderDetails作为一个集合,可能没有给出它具有复数名称。我将推断您的数据模型每个Order都有一个或多个OrderDetail条记录。 OrderDetail个对象的列表没有Notes属性。个人OrderDetail会这样做。我不确定RIA语法,但它应该是这样的:

condition = "( (it.CustomerName like 'test')  )  and  ( 
      (it.OrderDetails.Notes.Any(n => n.Contains('testnote') 
)";