父级上的 SQL 查询包括 EF 上的子项
本文关键字:EF 包括 SQL 查询 | 更新日期: 2023-09-27 18:35:47
我正在使用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')
)";