Linq从2个不同的实体框架加入查询

时间:2014-04-17 17:50:08

标签: c# linq entity-framework linq-to-entities

我正在使用2个实体框架。一个是项目数据库,另一个是员工数据库。我将项目经理的员工ID存储在项目数据库表中,但是当我不喜欢时,我必须从员工DB加入员工表,以显示员工姓名而不是员工ID。

如何加入两个实体。

1 个答案:

答案 0 :(得分:6)

有一些不同的方法来实现这一点。

您可以在其中一个连接不同dbs的两个表的数据库上创建一个视图,然后它将是Entity Framework中的一个对象。

您还可以首先从要连接的每个表中获取作为内存中对象的对象,这些对象与EF断开连接。显然,在将表/结果拉入内存之前,您希望在数据库端尽可能多地进行过滤。然后你可以加入断开连接的对象

var projects = db1.projects.Where(p=> /** filter here **/).Select(p=> /** select new anonymous type **/).ToList()

var employees = db2.employees.Where(e=> /** filter here **/).Select(e=> /** select new anonymous type **/).ToList()

from p in projects
join e in employee
on p.managerid equals e.employeeid
select new { EmployeeId = e.EmployeeId, Project = p.ProjectName };