C#中使用LINQ和lambda实现左链接、右链接、内链接

C#中使用LINQ和lambda实现左链接、右链接、内链接

在 C# 中使用 LINQ 和 lambda 表达式可以实现左链接(Left Join)、右链接(Right Join)和内链接(Inner Join)操作。这些链接操作是针对两个数据集合之间的关联查询,用于获取满足特定条件的匹配项。下面是使用 LINQ 和 lambda 表达式分别实现这些链接操作的示例:

假设我们有两个数据集合:orderscustomers,并且它们之间有一个共同的属性 CustomerId

  1. 左链接(Left Join):

左链接返回两个集合中的所有元素,并且还包括满足指定条件的匹配项。如果右侧的集合没有匹配项,将使用默认值表示。

csharp 复制代码
var leftJoinQuery = from customer in customers
                    join order in orders on customer.CustomerId equals order.CustomerId into customerOrders
                    from co in customerOrders.DefaultIfEmpty()
                    select new { customer.CustomerName, OrderId = co?.OrderId ?? 0 };

使用 Lambda 表达式:

csharp 复制代码
var leftJoinQuery = customers.GroupJoin(
    orders,
    customer => customer.CustomerId,
    order => order.CustomerId,
    (customer, customerOrders) => new
    {
        customer.CustomerName,
        OrderId = customerOrders.Select(co => co?.OrderId ?? 0).FirstOrDefault()
    }
);
  1. 右链接(Right Join):

右链接返回两个集合中的所有元素,并且还包括满足指定条件的匹配项。如果左侧的集合没有匹配项,将使用默认值表示。

csharp 复制代码
var rightJoinQuery = from order in orders
                     join customer in customers on order.CustomerId equals customer.CustomerId into orderCustomers
                     from oc in orderCustomers.DefaultIfEmpty()
                     select new { CustomerName = oc?.CustomerName ?? "N/A", order.OrderId };

使用 Lambda 表达式:

csharp 复制代码
var rightJoinQuery = orders.GroupJoin(
    customers,
    order => order.CustomerId,
    customer => customer.CustomerId,
    (order, orderCustomers) => new
    {
        CustomerName = orderCustomers.Select(oc => oc?.CustomerName ?? "N/A").FirstOrDefault(),
        order.OrderId
    }
);
  1. 内链接(Inner Join):

内链接返回两个集合中满足指定条件的匹配项。

csharp 复制代码
var innerJoinQuery = from order in orders
                     join customer in customers on order.CustomerId equals customer.CustomerId
                     select new { customer.CustomerName, order.OrderId };

使用 Lambda 表达式:

csharp 复制代码
var innerJoinQuery = orders.Join(
    customers,
    order => order.CustomerId,
    customer => customer.CustomerId,
    (order, customer) => new { customer.CustomerName, order.OrderId }
);

以上是使用 LINQ 和 lambda 表达式实现左链接、右链接和内链接操作的示例。通过掌握这些查询技巧,你可以更灵活地处理数据集合之间的关联查询。

相关推荐
kaikaile19953 小时前
数字全息图处理系统(C# 实现)
开发语言·c#
lizhihai_996 小时前
股市学习心得-AI 产业链核心标的梳理清单
大数据·服务器·人工智能·科技·学习
黄同学real7 小时前
解决 Visual Studio Web Deploy 远程发布报 401 未授权 (ERROR\_USER\_UNAUTHORIZED)
服务器
天天进步20157 小时前
Tunnelto 源码解析 #9:控制服务器设计:Warp、WebSocket、Ping/Pong 与连接保活
运维·服务器·websocket
Java面试题总结8 小时前
Linux-Ubantu-贴士-apt的地盘
linux·运维·服务器
●VON8 小时前
AtomGit Flutter鸿蒙客户端:数据模型
android·服务器·安全·flutter·harmonyos·鸿蒙
wearegogog1238 小时前
C# .NET 文件比较工具 WinForms
开发语言·c#·.net
酉鬼女又兒9 小时前
零基础入门计算机网络:网络层核心任务、三大关键问题、两种服务类型与 TCP/IP 网际层协议体系全解析
服务器·网络·网络协议·tcp/ip·计算机网络·php·求职招聘
糖不吃9 小时前
WPF值转换器
c#
Gauss松鼠会9 小时前
【GaussDB】GaussDB重要通信参数汇总
服务器·网络·数据库·sql·性能优化·gaussdb·经验总结