我目前在我的应用程序中有这个LINQ/EF代码:
var rootCategoryItem = DatabaseContext.Categories .Include("SubCategories") .OrderBy(c => c.CategoryOrder) .Single(c => c.CategoryId == 1);
我知道在EF你不能过滤器中包含的项目着呢,我可以写一些代码LINQ过滤掉不需要的子类别...但LINQ代码将被转换成一个可怕的SQL是高度未优化.我也可以编写一个执行此操作的存储过程(并编写比LINQ更好的查询),但我真的想使用纯EF.
所以我留下了两个选项(除非有人可以看到其他选项).
第一个是遍历子类别,删除不需要的子类别:
var subCategoriesToFilter = rootCategoryItem.SubCategories.ToList(); for (int i = 0; i < subCategoriesToFilter.Count; i++) { if (subCategoriesToFilter[i].Deleted) rootCategoryItem.SubCategories.Remove(subCategoriesToFilter[i]); }
第二种选择是在我看来:
在2中,哪一个是最好的选择?或者我还有另一种选择吗?
解决方案
好的,Servy的非常正确,我不得不修改他的答案以使其工作:
var rootCategoryItem = DatabaseContext.Categories .OrderBy(c => c.CategoryId) .ToList().Select(c => new Category() { SubCategories = c.SubCategories.Where(sub => !sub.Deleted).ToList(), //make sure only undeleted subcategories are returned CategoryId = c.CategoryId, CategoryName = c.CategoryName, Category_ParentID = c.Category_ParentID, CategoryOrder = c.CategoryOrder, Parent_Category = c.Parent_Category, Deleted = c.Deleted }).Single(c => c.CategoryId == 1);
我试图让Servy的解决方案工作有几个错误:
无法在LINQ to Entities查询中构造实体或复杂类型".Category"
无法将类型隐式转换为System.Collections.Generic.ICollection.存在显式转换(您是否错过了演员?)
通过在Select()方法之前添加.ToList()来解决这个问题.