1

我正在使用自我跟踪实体模型。ProductInstallation是一个 DTO,其中包含有关公司产品安装的所有详细信息。

UserRoles实体持有产品-系统角色-用户ID之间的关系。

举个例子:

产品:库存

系统角色:采购用户

用户 ID : hasithaH <- (假设我)

使用下面的 LINQ 查询,我可以获得不同的用户 ID。

string[] userIDs = productInstallation.UserRoles
                  .Select(u=>u.UserID).Distinct().ToArray();

现在我需要获取我在上述步骤中查询的用户 ID 的所有用户配置文件。

productInstallation.SystemUsers = context.SystemUsers.Select(u=> u.UserID ..??? 

从 SQL 的角度来看,这是我想要的查询:

Select * from SystemUsers where UserID in ('UserA','UserB','UserC')

我应该如何编写一个 LINQ 查询来完成这项工作?

4

3 回答 3

2

你这样写:

var result = context.SystemUsers.Where(su => 
               productInstallation.UserRoles.Any(ur => su.UserID == ur.UserId));

或者如果两个来源不是IQuerable来自同一个数据库:

string[] userIDs = productInstallation.UserRoles
                  .Select(u=>u.UserID).Distinct().ToArray();

var result = context.SystemUsers.Where(su => 
                   userIDs.Contains(su.UserID));
于 2013-06-17T17:51:30.130 回答
1

你可以试试这个:

productInstallation.SystemUsers = 
context.SystemUsers.FindAll(u=> userIDs.Contains(u.UserID))
于 2013-06-17T17:55:22.530 回答
1

您真正想要在这里做的是加入这两个表。使用 Join 您可以在一个查询中执行此操作,而不是执行两个单独的查询:

var systemUsers = from userRole in UserRoles
                  join systemUser in SystemUsers
                  on userRole.UserID equals systemUser.UserID
                  select systemUser;
于 2013-06-17T18:04:44.600 回答