我引用接受这个问题的答案: LINQ to SQL multiple tables left outer joinLinq Group加入(加入...)INNER JOIN的结果?
在我的例子,我需要所有的人记录,而不管是否有匹配的员工记录。
我使用下面的查询(简化illustation的缘故):
var result = from person in context.Person
join staffQ in context.Staff
on person.StaffID equals staffQ.ID into staffStaffIDGroup
from staff in staffStaffIDGroup.DefaultIfEmpty()
select new PersonModel()
{
ID = person.ID,
Fname = person.Fname,
Lname = person.Lname,
Sex = person.Sex,
Username = staff != null ? staff.Username : ""
};
然而,出乎我的意料,查询结果在下面的SQL与内部连接,从而消除了我需要的记录结果集。
SELECT
[Extent1].[ID] AS [ID],
[Extent1].[fname] AS [fname],
[Extent1].[lname] AS [lname],
[Extent1].[sex] AS [sex],
[Extent2].[username] AS [username]
FROM [dbo].[Person] AS [Extent1]
INNER JOIN [dbo].[Staff] AS [Extent2] ON [Extent1].[StaffID] = [Extent2].[ID]
我以为GroupJoin(或加入...到)应该绕过这个?我知道我一定在这里犯了一个愚蠢的错误,但我看不到它。
就是这样。几年前我也碰到过这个,并且完全忘了。 – esmoore68