gpt4 book ai didi

.net - 如何在LINQ中向实体进行LEFT JOIN?

转载 作者:行者123 更新时间:2023-12-04 21:42:55 25 4
gpt4 key购买 nike

最近两天,我一直在尝试找出如何在LINQ上进行真正的LEFT JOIN,但我一直没有成功。
我有一个用户表,其中包含“Primary2Address”列,该列可能并且通常为NULL。
所以我必须在这里做一个LEFT JOIN。另外,在“地址”表中,我有更多可能为NULL的关系,因此我必须执行多个LEFT JOINS。
我所做的每一次LINQ尝试都会输出一些带有UNIONS的严重疯狂的sql语句,嵌套的SELECT语句和其他古怪的东西。
我需要的是:

SELECT u.UserName FROM Users u 
LEFT JOIN Addresses a ON a.AddressiD = u.Primary2Address
LEFT JOIN States s ON s.StateID = a.Address2State
LEFT JOIN Countries c ON c.CountryID = a.CountryID

请帮助! 到目前为止,我的变通办法是创建一个使用上面的sql语句的存储过程,但是我真的很想尝试使用LINQ(L2E)来做到这一点。
谢谢你们!

最佳答案

DefaultIfEmpty用于EntityFramework 4+的左联接

var query = from u in context.Users
from a in context.Addresses
.Where(x => u.Primary2Address == x.AddressiD)
.DefaultIfEmpty()
from s in context.States
.Where(x => a.Address2State == x.StateID)
.DefaultIfEmpty()
from c in context.Countries
.Where(x => a.CountryID == x.CountryID)
.DefaultIfEmpty()
select u.UserName;

关于.net - 如何在LINQ中向实体进行LEFT JOIN?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8139160/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com