c# - 连接子句中的可选条件 - Linq

标签 c# .net linq linq-to-entities

我有以下 linq 查询

 var resultGuardian = from s in _db.Students
     join sg in _db.StudentGuardians on s.StudentID equals sg.StudentID
     join g in _db.Guardians on sg.GuardianId equals g.GuardianId
     join lr in _db.luRelationTypes on sg.RelationTypeID equals lr.RelationTypeID
     join ga in _db.GuardianAddresses on g.GuardianId equals ga.GuardianId
     join ad in _db.Addresses on ga.AddressID equals ad.AddressID
     join lt in _db.luAddressTypes on ad.AddressTypeID equals lt.AddressTypeID
     join lg in _db.luGenders on g.GenderID equals (int?)lg.GenderID into ssts
     from gdnr in ssts.DefaultIfEmpty()
     where
         s.TenantID == tenantid && sg.TenantID == tenantid && g.TenantID == tenantid &&
         s.StatusId == (int?)Extension.StatusType.Active //1
         && g.StatusID == (int?)Extension.StatusType.Active &&
         lr.StatusID == (int?)Extension.StatusType.Active && lr.TenantID == tenantid &&
         s.StudentID == sid
     select new
     {
         g.FirstName,
         g.LastName,
         IsPrimary = sg.IsPrimaryGuardian,
         g.Education,
         g.Email,
         g.Phone,
         lr.RelationCD,
         ga.IsStudentAddress,
         gdnr.GenderCD,
         lt.AddressName,
         ad.Address1,
         ad.Address2,
         ad.City,
         ad.State,
         ad.Zipcode

     };

在上面的查询中,当 ad.AddressTypeIDnull 时,它不会返回任何结果。

如果 ad.AddressTypeIDnull,我有要求,而不是从 LuAddressTypes 获取默认记录,其中 AddressTypeCd=1。如果我这样尝试

join lt in LuAddressTypes on ad.AddressTypeID equals lt.AddressTypeID into v1
from v2 in v1.DefaultIfEmpty()
select new
     {      
         v2.AddressName,
         g.Phone,..

     });

在结果 v2.AddressName 中总是返回 null。我也无法指定 AddressTypeCd=1 where 条件。 AddressTypeCd=1 不是 ad.AddressTypeID

我需要 v2.AddressName,其中 AddressTypeCd=1。我怎样才能做到这一点? 查找相关实体 all related entities

最佳答案

您不能使用标准的 LINQ join,但在 LINQ to Entities 中,您可以使用基于相关 Where 的替代连接语法 - EF 足够智能以进行翻译它加入JOIN

在你的情况下,而不是

join lt in _db.luAddressTypes on ad.AddressTypeID equals lt.AddressTypeID

你可以用

from lt in _db.luAddressTypes.Where(lt => ad.AddressTypeID == lt.AddressTypeID
    || (ad.AddressTypeID == null && lt.AddressTypeCd == 1))

翻译成这样

INNER JOIN [dbo].[LuAddressTypes] AS [Extent3]
    ON ([Extent2].[AddressTypeID] = [Extent3].[AddressTypeID])
        OR (([Extent2].[AddressTypeID] IS NULL) AND (1 = [Extent3].[AddressTypeCd]))

如果您想要LEFT OUTER JOIN,只需在上面一行的末尾添加.DefaultIfEmpty()

关于c# - 连接子句中的可选条件 - Linq,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53428500/

相关文章:

c# - IGrouping<int, Keypair> 到字典

c# - 无法加载文件或程序集 'System.Web.Mvc' 或其依赖项之一。 2个项目。一次只有一个会工作

.net - WCF MSMQ 的观察者模式

c# - 通过 LINQ 使用通用列表中的值格式化字符串

时间:2019-03-17 标签:c#linqconditionalunion

c# - 未处理的异常 - 0x800a1391 - JavaScript 运行时错误 : 'SelectAllCheckBoxes' is undefined

c# - 为什么在此运算符定义中抛出 stackoverflowexception?

c# - 如何检查字符数组中是否存在特定字符

c# - 提取列表的 k 个最大元素

c# - 将字符串转换为异常