首页 >后端开发 >C++ >如何使用 Lambda 表达式在 LINQ 中连接多个表?

如何使用 Lambda 表达式在 LINQ 中连接多个表?

Susan Sarandon
Susan Sarandon原创
2025-01-10 10:58:42287浏览

How to Join Multiple Tables in LINQ Using Lambda Expressions?

使用LINQ Lambda表达式连接多个表

在LINQ中处理多个表时,您可能需要将它们连接起来以收集相关数据。这可以通过LINQ中的lambda表达式来实现。

假设以下场景:

  • 您拥有Product、Category和ProductCategory(关联表)的类。
  • 您希望连接所有三个表,并使用特定属性填充另一个对象(CategorizedProducts)。

以下是使用lambda表达式执行连接的代码更新版本:

<code class="language-csharp">var categorizedProducts = product
    .Join(productcategory, p => p.Id, pc => pc.ProdId, (p, pc) => new { p, pc })
    .Join(category, ppc => ppc.pc.CatId, c => c.Id, (ppc, c) => new { ppc, c })
    .Select(m => new CategorizedProducts
    {
        ProdId = m.ppc.p.Id, // 或 m.ppc.pc.ProdId
        CatId = m.c.CatId,
        // 其他赋值
    });</code>

在此代码中:

  • Join操作根据指定的条件连接表。
  • 匿名类型作为连接数据的中间表示。
  • Select操作将所需属性投影到CategorizedProducts对象中。

此解决方案提供了一个包含连接表中所有属性的单个类,允许您根据需要填充CategorizedProducts对象。

以上是如何使用 Lambda 表达式在 LINQ 中连接多个表?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn