gpt4 book ai didi

c# - 如何使用 LINQ 对 1 个表返回父项和子项

转载 作者:行者123 更新时间:2023-11-30 16:19:46 25 4
gpt4 key购买 nike

一直在为此寻找解决方案,但到目前为止还没有找到。

我相当确定它可以通过一个 linq 调用实现,但无法解决。

我有以下数据结构

Id      ParentId     Name       ValidFlag

1 NULL parent 1 1
2 NULL parent 2 1
3 NULL parent 3 0
4 1 child 1 1
5 1 child 2 1
6 2 child 3 1
7 2 child 4 1
8 3 child 5 1
9 3 child 6 1

现在我想做的是返回所有有效的 parent 和他们的 child ,所以在这种情况下我会返回除 Id = 3( parent 3)之外的所有内容。

是否有使用 LINQ 执行此操作的简单方法?我猜有,但我的 LinqIQ 非常有限,我知道基础知识,但除此之外我需要很多帮助。

这是 ToLookup() 或 Union 的情况还是两者都不是?

更新:

更具体地说,因为我没有这样做,两种类型的记录都在同一个表中,如果可能的话,我想在第一个查询中返回所有记录,无论是父记录还是子记录。

它不像只选择 ValidFlag = 1 的所有记录那么简单。源数据库一团糟,获取所有记录的唯一方法是找到“有效” parent ,然后找到“有效” parent 的所有 child 。我知道我可以做一个简单的查询来返回所有有效的父记录,然后做一个单独的查询来找到这些 parent 的所有 child ,但是合并到 1 个 LINQ 查询是我失败的地方,我希望这是可能的。在这种情况下,可能存在无效 parent 的有效子条目,因此需要这个问题

最佳答案

这应该可以解决问题,(编辑:请参阅下面的不使用 Distinct 的版本。)

(from parents in collection
from all in collection
where
parents.ValidFlag == 1 &&
parents.ParentId == null &&
all.ValidFlag == 1 &&
(all.ParentId == null || all.ParentId == parents.Id)
select all).Distinct();

上面的代码应该会生成一些非常类似于它本身在 SQL 中的样子,也许除了distinct 这可能会导致它返回更多实际上是需要在客户端进行过滤。可能成为的东西问题是否有很多数据,主要是如果有很多 parent 因为它会返回那些的副本)

这是在没有 distinct 调用的情况下重新处理的查询

from parents in collection // parents is only used to decide which children to get
from all in collection // this is where we will actually grab our data from
where
parents.ValidFlag == 1 && // only include parents that are valid
parents.ParentId == null && // and that are parents
all.ValidFlag == 1 && // only include entries that are valid
(
(all.ParentId == null && all.Id == parents.Id) || // If entry is a parent, match with itself to limit returns to 1
all.ParentId == parents.Id // otherwise, parentid should match one of the valid parents.
)
select all

关于c# - 如何使用 LINQ 对 1 个表返回父项和子项,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14994383/

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