我最近开始了一个新的 webforms 项目,并决定将业务类与任何 DBML 引用分开。我的业务层类改为访问离散的数据层方法,并返回 DTO 的集合。所以数据层可能会像下面这样投射 DTO:
(from c in dataContext.Customers
where c.Active == true
select new DTO.Customer
{
CustomerID = c.CustomerID,
Name = c.CustomerName,
...
}).ToList()
尽管构建 DTO 对象会增加工作量,但这感觉像是在业务层和数据层之间紧密绑定的更好方法,这意味着我可以在没有数据库的情况下测试业务层。
我的问题是,这是一种好的做法吗?,有没有一种方法可以生成 DTO(可能通过 SQLMetal),以及随着项目的进展我可能会遇到哪些其他问题。