- r - 以节省内存的方式增长 data.frame
- ruby-on-rails - ruby/ruby on rails 内存泄漏检测
- android - 无法解析导入android.support.v7.app
- UNIX 域套接字与共享内存(映射文件)
谁能解释一下 GroupJoin()
是什么?
它与常规 Join()
有何不同?
常用吗?
它只针对方法语法吗?查询语法呢? (一个 c# 代码示例会很好)
最佳答案
假设您有两个列表:
Id Value
1 A
2 B
3 C
Id ChildValue
1 a1
1 a2
1 a3
2 b1
2 b2
当你 Join
Id
上的两个列表结果将是:
Value ChildValue
A a1
A a2
A a3
B b1
B b2
当你 GroupJoin
Id
上的两个列表结果将是:
Value ChildValues
A [a1, a2, a3]
B [b1, b2]
C []
所以 Join
生成父值和子值的平面(表格)结果。
GroupJoin
在第一个列表中生成一个条目列表,每个条目在第二个列表中都有一组连接的条目。
这就是为什么 Join
相当于INNER JOIN
在 SQL 中:没有 C
的条目.同时 GroupJoin
相当于OUTER JOIN
: C
在结果集中,但相关条目列表为空(在 SQL 结果集中会有一行 C - null
)。
所以让两个列表为IEnumerable<Parent>
和 IEnumerable<Child>
分别。 (如果是 Linq to Entities:IQueryable<T>
)。
Join
语法为
from p in Parent
join c in Child on p.Id equals c.Id
select new { p.Value, c.ChildValue }
返回 IEnumerable<X>
其中 X 是具有两个属性的匿名类型,Value
和 ChildValue
.此查询语法使用 Join
引擎盖下的方法。
GroupJoin
语法为
from p in Parent
join c in Child on p.Id equals c.Id into g
select new { Parent = p, Children = g }
返回 IEnumerable<Y>
其中 Y 是一个匿名类型,由一个 Parent
类型的属性组成和 IEnumerable<Child>
类型的属性.此查询语法使用 GroupJoin
引擎盖下的方法。
我们可以做 select g
在后一个查询中,它将选择 IEnumerable<IEnumerable<Child>>
,说一个列表列表。在许多情况下,包含父项的选择更有用。
如前所述,声明...
from p in Parent
join c in Child on p.Id equals c.Id into g
select new { Parent = p, Children = g }
... 生成带有子组的父列表。这可以通过两个小的添加变成一个简单的父子对列表:
from p in parents
join c in children on p.Id equals c.Id into g // <= into
from c in g.DefaultIfEmpty() // <= flattens the groups
select new { Parent = p.Value, Child = c?.ChildValue }
结果类似于
Value Child
A a1
A a2
A a3
B b1
B b2
C (null)
注意范围变量 c
在上面的语句中被重用。这样做,任何 join
语句可以简单地转换为 outer join
通过添加相当于 into g from c in g.DefaultIfEmpty()
到现有的 join
声明。
这是查询(或综合)语法的亮点所在。方法(或流利)语法显示了真正发生的事情,但很难写:
parents.GroupJoin(children, p => p.Id, c => c.Id, (p, c) => new { p, c })
.SelectMany(x => x.c.DefaultIfEmpty(), (x,c) => new { x.p.Value, c?.ChildValue } )
太平了outer join
在 LINQ 中是 GroupJoin
, 被 SelectMany
压平.
假设 parent 名单有点长。某些 UI 会生成一个选定的 parent 列表,格式为 Id
。固定顺序的值。让我们使用:
var ids = new[] { 3,7,2,4 };
现在必须按此确切顺序从 parent 列表中过滤出选定的 parent 。
如果我们这样做......
var result = parents.Where(p => ids.Contains(p.Id));
... parents
的顺序将决定结果。如果 parent 是按Id
点的,结果将是 parent 2、3、4、7。不好。但是,我们也可以使用 join
过滤列表。并通过使用 ids
作为第一个列表,顺序将被保留:
from id in ids
join p in parents on id equals p.Id
select p
结果是 parent 3, 7, 2, 4。
关于c# - Linq-to-Entities 加入与 GroupJoin,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15595289/
我有这 2 个列表 list1 和 list2 并创建了这个 GroupJoin: List1 是人员列表(Id、姓名),list2 是对象列表(Id、Car、Date)。 PS:list1 包含大约
在 GroupJoin 之后,我想包括 Book.Authors,因为字段 Book.Authors 将为空。但我不能。我应该怎么做才能解决这个问题? Queryable recent = Repos
我想在两个集合之间执行 GroupJoin,但基于除相等性之外的其他谓词。例如,如果我有一个包含项目的集合,每个项目都包含一个范围属性,我想将它们中的每一个与另一个集合中的项目相关联,该集合的某些属性
基本上,我想做的是左外连接两个表并将它们呈现在一个平面结果中。为简单起见,我的两个表如下所示: tot["nameA", "nameB", "nameC"] critItg["nameA", "nam
我对使用 Entity Framework 还很陌生,并且一直遇到代码无法编译的问题。我收到的错误消息是: The type arguments for method 'System.Linq.Que
我有一个看起来(简化)如下的数据库: var reports = new[] { new { ReportId = 1, Title = "Report A" }, new { Rep
我想花 5-6 个小时来了解有关 GroupJoin 的一些事情。我正在谈论使用 linq 查询数据库表。我了解 Join 和 GroupJoin 的作用,但我真的不明白我在哪里需要它。我觉得 Joi
我有以下代码 var profilesWithMailLists = profilesWithCf.GroupJoin( profile2Maillist,
我该如何解释(严重?)? 我有一个名为“规则”的实体,它是一些用于从 POCO[] 中挑选项目的“选择器”。有一定数量的字段可供选择。所有这些都在我的数据库对象中有详细说明。 我需要在网格中显示规则,
我有一个返回如下结果的 GroupJoin 查询: IEnumerable query = ICDUnitOfWork.AlphaGroups.Find() .GroupJoin(ICDUni
The GroupJoin method has no direct equivalent in relational database terms, but it implements a supe
这是我的代码显示的错误 Severity Code Description Project File Line Suppression State Error CS0411 The type argu
我一直在尝试使用 Join 和 GroupJoin 方法。问题看起来很简单。给定 TableA 和 TableB 作为数据映射,这样: class MyDataContext : DataContex
我已经生成/测试了两个要组合起来执行单个查询的 Observable。 一个用户可以有多个角色。每当他们的角色 ID 发生变化时,就需要更新数据。但是数据应该只在查询处于事件状态时更新(当前有一些控件
谁能解释一下 GroupJoin() 是什么? 它与常规 Join() 有何不同? 常用吗? 它只针对方法语法吗?查询语法呢? (一个 c# 代码示例会很好) 最佳答案 行为 假设您有两个列表: Id
我不明白为什么这不翻译。这似乎正是描述的用例 here . LINQ 表达式 DbSet() .GroupJoin( inner: DbSet(), outer
这是我第一次使用 GroupJoin。从我看到的示例来看,在其基本形式中使用似乎非常简单,但是当我使用它时,我总是会遇到 NavigationExpandingExpressionVisitor 异常
以下代码: const Rx = require('rx'); const gameRowObservable = Rx.Observable.fromArray([{ game_id: 1,
我正在尝试使用 GroupJoin 和 SelectMany 在 linq 中执行“左外连接”,但随后我还想使用 GroupBy 和 Sum 聚合结果。 但是当我执行下面的代码时,我得到: Syste
我有以下类(class) public class OrderItem { public Guid ID { get; set; } public Guid? ParentID { g
我是一名优秀的程序员,十分优秀!