[英]SQL Query on Parent Include Child on EF
我正在使用RIA Services-MVVM模式在C#上使用Silverlight。 当我尝试从Orders
和OrdersDetails
获取记录时,出现以下错误:
“注释”不是的成员
'Transient.collection [XXX.SilverLight.Web.Models.OrderDetails(Nullable = True,DefaultValue =)]'。
要提取集合元素的属性,请使用子查询来遍历集合。 在简单标识符附近,第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') )";
然后,它很棒。
您正在尝试使用它it.OrderDetails
作为一个集合,可能没有给出它的复数名称。 我将推断您的数据模型是每个Order
都有一个或多个OrderDetail
记录。 OrderDetail
对象的列表没有Notes
属性。 一个单独的OrderDetail
可以。 我不确定RIA语法,但是应该是这样的:
condition = "( (it.CustomerName like 'test') ) and (
(it.OrderDetails.Notes.Any(n => n.Contains('testnote')
)";
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.