簡體   English   中英

使用LINQ GroupBy獲得不同的結果以實現復雜的實體關系?

[英]Get distinct results using LINQ GroupBy for complex entity relationships?

以下是我的人際關系的簡要概述:

one Account has many AccountRoles
one AccountRole has many UserAccountRoles
many UserAccountRoles can have one User

我需要獲得的是一個Account的所有User的集合。

我怎么能在LINQ中這樣做?

編輯:

這是我到目前為止所嘗試的:

var dto = _context.Set<Model.Account>()
    .Find(account.Id);

if (dto == null)
    return null;

var userAccountRoleDTOs = dto.AccountRoles
    .Select(ar => ar.UserAccountRoles);

var userDTOs = userAccountRoleDTOs
    .Select(uar => uar.Select(uar2 => uar2.User));

return userDTOs;

userDTOsreturn集合的集合。 這對我來說沒什么意義。

由於最終你想要的只是一個用戶的扁平化集合,你應該能夠使用SelectMany()來展平一對多關系,然后在最后調用Distinct()

var users = dto.AccountRoles
    .SelectMany(ar => ar.UserAccountRoles.Select(uar => uar.User))
    .Distinct();

或者,以查詢形式

var users = (from ar in dto.AccountRoles
             from uar in ar.UserAccountRoles
             select uar.User)
            .Distinct();

或者你可以走另一條路:

from u in context.Users
where u.UserAccountRoles.Any(uar=>uar.AccountRole.Account.Id == someAccountId)

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM