我使用域模型和存储库实现了DDD的命令端,但是如何实现查询方面?
我是否为UI创建了一个全新的领域模型,并且在域层,UI层等中保留在项目结构中的哪里?
从我对CQRS的了解,您将创建一个满足用户界面屏幕或可能需要消费的应用程序需求的DTO。
项目中存在的是基于要求,因为您将通过Web服务公开这些DTO。
在这种情况下,我不会把它放在Web层,而是在应用层或专用的外墙层中。
那么您将拥有只读存储库或数据访问层,直接填充DTO。我认为,查询方面的事情应该被优化为读取性能,在这种情况下,数据库视图或表和sqlDataReaders上的直接查询/存储过程将在这里做最好的工作。但是,这绝对值得抽象出一个接口后面的这个访问,所以你可以在轨道上添加一个缓存的实现。
如果您正在使用ORM,并希望将域实体映射到DTO,那么您可以拥有一个通用的QueryRepository,它具有使用ISpecification或类似结构定义查询的方法,然后使用DtoAssembler对象从您的域创建Dtos对象。
然后,一个实现对您要执行的每个查询都有一个第一类对象。
这是一个相当有创意的例子,但我希望它给你一个想法。
public interface ISpecification<T> { Expression<Func<T,bool>> Predicate { get; } } public class ActiveCustomeRSSpecification : ISpecification<Customer> { private Expression<Func<Customer,bool>> predicate; public ActiveCustomeRSSpecification() { predicate = c => c.IsActive; } #region ISpecicfication<Customer> Members public Expression<Func<Customer,bool>> Predicate { get { return predicate; } } #endregion } public interface IQueryRepository<T> { IQueryable<T> GetQuery(ISpecification<T> specification); IEnumerable<T> FindAllBy(ISpecification<T> specification); } public class CustomerDtoAssembler { public CustomerDto AssembleFrom(Customer customer) { var customerDto = new CustomerDto { Id = customer.Id }; return customerDto; } }