如何解决.Net Core Web API-如何填充包含通用列表的DTO
我的数据模型由Employee表和Projects表之间的一对多关系组成。我需要DTO返回一个Employee对象,该对象包含Project对象的集合/列表。我正在使用存储库模式从数据库返回数据。问题1:如何填充DTO的List属性?问题2:我的方法正确吗?问题3:我以IEnumerable的形式返回Project对象的列表。我的DTO中的Projects属性是否应该是List,IList,Collection?这是我的代码。预先谢谢你。
//My DTO
public class EmployeeReadDto
{
public int Id { get; set; }
public string FName { get; set; }
public string LName { get; set; }
public string Email { get; set; }
public ICollection<Project> Projects { get; set; }
}
//GetAll signature from my generic repository
public IEnumerable<T> GetAll()
//Controller where I am trying to populate DTO
[HttpGet("{id}",Name = "employee/GetById")]
public ActionResult<EmployeeReadDto> GetById(int id)
{
var projects = _projectRep.GetAll();
var employee = _employeeRep.GetById(id);
var dto = new EmployeeReadDto
{
Id = employee.Id,FName = employee.FName,LName = employee.LName,Email = employee.Email,Projects = projects
};
return Ok(dto);
}
解决方法
问题1:如何填充DTO的List属性?题 2:我的方法正确吗?问题3:我要返回清单 项目对象作为IEnumerable。项目属性是否应位于 我的DTO是列表,IList,集合?
-
IEnumerable<T>
实现IEnumerable接口方法以改进 可以迭代的集合。 -
ICollection<T>
继承IEnumerable和IEnumerable 接口。 -
IList
继承了IEnumerable和ICollection接口。 -
List
是一个类,不仅实现其接口,而且实现 扩展了更多方法。
因此,将Project对象的列表作为IEnumerable返回是不正确的,但它可以作为List,IList,ICollection
返回。
尝试如下更改代码:
public List<T> GetAll()
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。