过滤包括LINQ和实体框架中的项目

 CleanTheString 发布于 2022-12-23 18:39

我目前在我的应用程序中有这个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]);
        }

第二种选择是在我看来:

    @foreach (var categoryitem in Model.SubCategories.OrderBy(c => c.CategoryOrder)) { @if(!Model.Deleted) {
  • @Model.CategoryName
  • } }

在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()来解决这个问题.

撰写答案
今天,你开发时遇到什么问题呢?
立即提问
热门标签
PHP1.CN | 中国最专业的PHP中文社区 | PNG素材下载 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有