Linq left join 怎么写??? 求正解!

Jueyoung 2010-08-12 02:00:00
要求 分别实现类似以下两种情况的 Linq 语句

谢谢!

select * 
from table1
left join table2 on table1.Id = table2.empId
left join table3 on table2.deptId = table3.deptId
where table1.id > 10



select * 
from table1
left join table2 on table1.Id = table2.empId
left join table3 on table1.deptId = table3.deptId
where table1.id > 10


...全文
720 10 打赏 收藏 转发到动态 举报
写回复
用AI写文章
10 条回复
切换为时间正序
请发表友善的回复…
发表回复
Jueyoung 2010-08-12
  • 打赏
  • 举报
回复
LINQ to Entities does not recognize the method , and this method cannot be translated into a store expression.

为什么啊???
Jueyoung 2010-08-12
  • 打赏
  • 举报
回复
[Quote=引用 6 楼 q107770540 的回复:]

C# code

//1 .
DbContext db=new DbContext ();
var q=from t1 in db.Table1
join t2 in db.Table2
on t1.Id equals t2.empId
join t3 in db.Table3
……
[/Quote]


这样貌似就是 inner join 了呀
Jueyoung 2010-08-12
  • 打赏
  • 举报
回复
谢谢各位 我要逐一再试一试
wuyq11 2010-08-12
  • 打赏
  • 举报
回复
var q =
from e in db.Employees
join o in db.Books on e.EmployeeID equals o.EmployeeID into b
from x in b.DefaultIfEmpty()
select new
{
e.ID,
e.Name,
o.BookName
};
q107770540 2010-08-12
  • 打赏
  • 举报
回复

//1 .
DbContext db=new DbContext ();
var q=from t1 in db.Table1
join t2 in db.Table2
on t1.Id equals t2.empId
join t3 in db.Table3
on t2.deptId equals t3.detpId
where t1.id>10
select new {t1.id,t1......}


//2

DbContext db=new DbContext ();
var q=from t1 in db.Table1
join t2 in db.Table2
on t1.Id equals t2.empId
join t3 in db.Table3
on t1.deptId equals t3.detpId
where t1.id>10
select new {t1.id,t1......}

q107770540 2010-08-12
  • 打赏
  • 举报
回复
使用DefaultIfEmpty 翻译成SQL语句不是LEFT JOIN,而是LEFT OUT JOIN
醉爱 2010-08-12
  • 打赏
  • 举报
回复
你先看看tb里面有没有值
Jueyoung 2010-08-12
  • 打赏
  • 举报
回复
但是这样写 我用 tb.FirstOrDefault() 就出错呢?
醉爱 2010-08-12
  • 打赏
  • 举报
回复
1)
var tb = from tb1 in table1
join tb2 in table2 on tb1.Id equals tb2.empId into ggg
from gg in ggg.DefaultIfEmpty()
join tb3 in table3 on gg.deptId equals tb3.deptId into kkk
from kk in kkk.DefaultIfEmpty()
where (tb1.Id > 10)
select new
{
tb1.id
...
kk.deptId
...
};
2)
var tb = from tb1 in table1
join tb2 in table2 on tb1.Id equals tb2.empId into ggg
from gg in ggg.DefaultIfEmpty()
join tb3 in table3 on tb1.deptId equals tb3.deptId into kkk
from kk in kkk.DefaultIfEmpty()
where (tb1.Id > 10)
select new
{
tb1.id
...
kk.deptId
...
};
Jueyoung 2010-08-12
  • 打赏
  • 举报
回复
么有人呢?

110,565

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术 C#
社区管理员
  • C#
  • Web++
  • by_封爱
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

让您成为最强悍的C#开发者

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