linq如何同时实现left join与right join?

cicna 2013-12-11 11:29:54
我有三个表
User 用户表
UserOrg 用户组织关联表
Org 组织个
SQL语句是
select distinct * from User
left join UserOrg
on User.userid = UserOrg.userid
right join Org
on UserOrg.orgid = Org.orgid

Linq如何实现呢?
...全文
1049 2 打赏 收藏 转发到动态 举报
写回复
用AI写文章
2 条回复
切换为时间正序
请发表友善的回复…
发表回复
cicna 2013-12-12
  • 打赏
  • 举报
回复
引用 1 楼 q107770540 的回复:
var query=from o in Org
          join x in ( from u in User join uo in UserOrg
                 on u.userid equals uo.userid into lg
                 from uo in lg.DefaultIfEmpty()
                 select new {u,uo})
          on o.orgid equals x.orgid into lg2
          from x in lg2.DefaultIfEmpty()
          select o;
好思路left join (left join),按照这个做了果然行,谢谢版主。不过遇到了null值处理问题,详看http://bbs.csdn.net/topics/390667221
q107770540 2013-12-11
  • 打赏
  • 举报
回复
var query=from o in Org
          join x in ( from u in User join uo in UserOrg
                 on u.userid equals uo.userid into lg
                 from uo in lg.DefaultIfEmpty()
                 select new {u,uo})
          on o.orgid equals x.orgid into lg2
          from x in lg2.DefaultIfEmpty()
          select o;

8,497

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术 LINQ
社区管理员
  • LINQ
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧