gpt4 book ai didi

c# - 过滤包括 LINQ 和 Entity Framework 中的项目

转载 作者:可可西里 更新时间:2023-11-01 03:07:59 25 4
gpt4 key购买 nike

<分区>

目前我的应用程序中有此 LINQ/EF 代码:

var rootCategoryItem = DatabaseContext.Categories
.Include("SubCategories")
.OrderBy(c => c.CategoryOrder)
.Single(c => c.CategoryId == 1);

我知道在 EF 中你还不能过滤包含的项目,我可以写一些 LINQ 代码来过滤掉不需要的子类别......但是 LINQ 代码被转换成一个可怕的 SQL,这是非常不-优化。我也可以编写一个存储过程来执行此操作(并编写一个比 LINQ 好得多的查询),但我真的想使用纯 EF。

所以我只剩下 2 个选项(除非有人可以看到其他选项)。

首先是遍历子类别,删除不需要的:

        var subCategoriesToFilter = rootCategoryItem.SubCategories.ToList();

for (int i = 0; i < subCategoriesToFilter.Count; i++)
{
if (subCategoriesToFilter[i].Deleted)
rootCategoryItem.SubCategories.Remove(subCategoriesToFilter[i]);
}

第二个选项是在我看来:

<ul class="treeview ui-accordion-content ui-helper-reset ui-widget-content ui-corner-bottom ui-accordion ui-widget ui-sortable ui-accordion-content-active">
@foreach (var categoryitem in Model.SubCategories.OrderBy(c => c.CategoryOrder))
{

@if(!Model.Deleted)
{
<li class="treelistitem" id="@Model.CategoryId">
<div class="ui-accordion-header ui-state-default ui-corner-all ui-accordion-icons ui-sortable-handle first">
<span class="clickable">
<span class="ui-accordion-header-icon ui-icon treeviewicon treeviewplus"></span>
<i class="glyphicon glyphicon-folder-open rightfolderpadding"></i><span class="categoryname">@Model.CategoryName</span>
</span>
</div>
</li>
}
}
</ul>

在 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 的解决方案起作用时遇到了几个错误:

The entity or complex type '.Category' cannot be constructed in a LINQ to Entities query

Cannot implicitly convert type to System.Collections.Generic.ICollection. An explicit conversion exists (are you missing a cast?)

这一切都通过在 Select() 方法之前添加 .ToList() 来解决。

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com