CQS 架构模式背后的原则是将查询和命令分成不同的路径。理想情况下,您的持久性存储可以读/写分区,但在我的情况下,有一个单一的规范化数据库。
如果您使用的是 ORM(在我的例子中是 NHibernate),很明显在发出命令时使用了 ORM。但是,您需要运行所有各种查询来为用户屏幕塑造数据 (DTO),在执行 CQS 的查询端时放弃 ORM 是否普遍做法?
我应该在哪里实现我的查询和 DTO 预测?直接 ADO.NET(数据读取器、dto、数据表、存储过程)?一些查询是非常独特的,并且涉及很多连接来将所有内容组合在一起。我不想为查询对数据库进行非规范化,但我可以创建视图(穷人的非规范化)。