我有以下项目模型:
public class Project
{
[Key]
public int ProjectID { get; set; }
public string Name { get; set; }
public string Description { get; set; }
public virtual ICollection<Screenshot> Screenshots { get; set; }
}
我有以下截图模型:
public class Screenshot
{
[Key]
public int ScreenshotID { get; set; }
public string ScreenshotName { get; set; }
public byte[] ScreenshotContent { get; set; }
public string ScreenshotContentType { get; set; }
}
如您所见,每个项目都附有一些截图。在以下函数中,我想检索一些项目,只检索相应屏幕截图的ID。
public SearchResultDTO<ProjectDTO> GetProjects(SearchParametersProjectDTO dto)
{
...
var resultDTO = new SearchResultDTO<ProjectDTO>
{
Entities = Mapper.Map<IEnumerable<Project>, IEnumerable<ProjectDTO>>(projects.ToList()),
TotalItems = projects.Count()
};
return resultDTO;
}
这是ProjectDTO:
[DataContract]
public class ProjectDTO : BaseDTO<ProjectDTO, Project>
{
[DataMember]
public int ProjectID { get; set; }
[DataMember]
public string Name { get; set; }
[DataMember]
public string Description { get; set; }
[DataMember]
public IEnumerable<int> ScreenshotID { get; set; }
所以我不知道如何在我的DTO中映射ScreenshotID。
非常感谢任何帮助。
感谢。
答案 0 :(得分:0)
在Screenshot
和int
:
Mapper
.CreateMap<Screenshot, int>()
.ConvertUsing(s => s.ScreenshotID);
在Project
和ProjectDTO
之间的映射中使用它:
Mapper
.CreateMap<Project, ProjectDTO>()
.ForMember(
dest => dest.ScreenshotID,
opt => opt.MapFrom(src => src.Screenshots)
);
当你想要映射时:
var project = new Project
{
Screenshots = new[]
{
new Screenshot { ScreenshotID = 1 },
new Screenshot { ScreenshotID = 2 },
new Screenshot { ScreenshotID = 3 },
}
};
var projectDto = Mapper.Map<Project, ProjectDTO>(project);
// at this stage the projectDto.ScreenshotID collection will contain
// the necessary information