Linq - join

本文介绍了SQL查询中多条件连接和分组查询的应用,通过具体示例展示了如何使用JOIN、GROUP BY等操作来实现复杂的数据筛选与聚合,包括左连接查询、分组聚合及条件过滤技巧。
多条件:   
var queyAnnual = from A in queryVw
                                 join q in leaveDefault on new { A.LeaveType, A.EmployeeID } equals new { q.LeaveType, q.EmployeeCode }
                                 select new
                                 {
                                     A,
                                     AnnulLeaveTo = q.LeaveType
                                 };
 
var query = people.GroupJoin(pets, person => person, pet => pet.Owner, (person, petCollection) => new { OwnerName = person.Name, Pet = PetCollection.Select( p => p.Name ) .DefaultIfEmpty() } ).ToList();


左链接:

 

Group BY join

public IList<StructureRootDTO> GetRootStructureInfos()
        {
            using (ETCDataContext etcDataContext = this.EtcDataContext)
            {
                var query =
                       from item in
                           (
                               from parent in etcDataContext.SYS_Structures
                               where parent.ParentNode == "root"
                               join child in etcDataContext.SYS_Structures
                               on parent.Name equals child.ParentNode into childAll
                               from childItem in childAll.DefaultIfEmpty()
                               select new
                               {
                                   parent.ID,
                                   parent.Name,
                                   childItem.ParentNode
                               }
                           )
                       group item by item.Name into groupChild                      
                       select new StructureRootDTO
                       {
                           ID = groupChild.Max(o => o.ID),
                           Name = groupChild.Max(o => o.Name),
                           ChildParentNodeName = groupChild.Max(o => o.ParentNode)
                       };
                return query.OrderBy(o => o.ID).ToList();
            }
        }


 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值