簡體   English   中英

可查詢列表<dto>轉換</dto>

[英]IQueryable List<DTO> conversion

我需要使用 TeamsDTO 列表填充 UserDTO 的 IQueryable,而無需使用 foreach 循環或物化數據。

我有以下課程:

public class User
{
    public int Id {get;set;}
    public string Name {get;set;}
    public List<Team> Teams {get;set;}
}

public class Team
{
    public int Id {get;set;}
    public string Teamname {get;set;}
    public string Description {get;set;}
}

以及以下 DTO:

public class UserDTO
{
    public int Id {get;set;}
    public List<TeamDTO> TeamsDTOList{get;set;}
}

public class TeamDTO
{
    public int Id {get;set;}
    public string Teamname {get;set;}
}

到目前為止的代碼:

public static IQueryable<UserDTO> GetQueryableUserDTO(IQueryable<User> query)
        {
            var retQueryable = Enumerable.Empty<UserDTO>().AsQueryable();
            try
            {
                retQueryable = query.AsEnumerable()
                                .Select(k => new UserDTO
                                {
                                    Id = k.Id,
                                    TeamsDTOList= new List<TeamDTO>()
                                    {
                                        //Can't figure out this part
                                    }
                                });
            }
            catch (Exception ex)
            {
                BaseManager.Write2Log(ex);
            }
            return retQueryable;
        }

我在這里先向您的幫助表示感謝。

PS:類/代碼當然是一個簡化的例子。

那這個呢:

retQueryable = query.AsEnumerable().Select(k => new UserDTO()
                {
                    Id = k.Id,
                    TeamsDTOList = k.Teams.Select(t => new TeamDTO(){ Id = t.Id, Teamname = t.Teamname}).ToList()
                });

暫無
暫無

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

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