在EF中实现左联接

Posted penz

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了在EF中实现左联接相关的知识,希望对你有一定的参考价值。

当使用EF中的dbset进行join操作的时候如果,如果表之间没有关联关系的话,生成的sql语句是 inner join(inner join 和 left join的区别 就不在这阐述了),eg:

var user = await (from u in this.context.MUser.Where(sa => sa.Id == pid)
                  join uw in this.context.MUserWechat on u.Id equals uw.UserID 
                  select new MVUserBaseInfo
                  {
                      ID = u.Id,
                      CreateTime = u.CreateTime,
                      HeadImage = u.HeadImage,
                      Phone = u.Phone,
                      UserName = u.UserName,
                      WechatBindStatus = uwti.WechatBindStatus,
                      WechatSystem = uwti.WechatSystem,
                      WechatUser = uwti.WechatUser,
                      NickName = uwti.NickName ?? string.Empty
                  }).FirstOrDefaultAsync();

这样相当于就是将MUser和MUserWechat 进行了inner join, 如果我们希望进行左连接的话可以借助DefaultIfEmpty() 来达到当联接的表为空的时候,生成一条空的数据,从而达到左联接的效果,eg:

var user = await (from u in this.context.MUser.Where(sa => sa.Id == pid)
                  join uw in this.context.MUserWechat on u.Id equals uw.UserID into uwt
                  from uwti in uwt.DefaultIfEmpty() // 变成left join
                  select new MVUserBaseInfo
                  {
                      ID = u.Id,
                      CreateTime = u.CreateTime,
                      HeadImage = u.HeadImage,
                      Phone = u.Phone,
                      UserName = u.UserName,
                      WechatBindStatus = uwti.WechatBindStatus,
                      WechatSystem = uwti.WechatSystem,
                      WechatUser = uwti.WechatUser,
                      NickName = uwti.NickName ?? string.Empty
                  }).FirstOrDefaultAsync();

以上是关于在EF中实现左联接的主要内容,如果未能解决你的问题,请参考以下文章

如何在 SQL 中实现这种双重联接?

需要帮助在 MS Access 中实施完全外部联接

如何过滤 EF Core 中的多对多联接

如何将领域类与EF代码第一层分离并在项目中实现DDD

如何在使用 TPT 层次结构时首先在 EF 代码中实现并发

更改生成的联接表的名称(多对多)-EF Core 5