- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
在一个学习更多关于 DDD 模式的个人游戏项目的上下文中,我缺少一个 Specification我的过滤器的对象。
环顾四周,似乎一切(如 LinQ)都面向 SQL 数据库。然而,对于许多 NoSQL 数据库,大多数查询,即使只是“从表中选择 *”也需要预定义的 View 。然而,如果存储库正在映射 Web 服务,那么查询的类型也会更加严格。
考虑到非 SQL 数据库的限制,规范模式是否存在变体?我觉得这需要使用继承和静态声明来支持不同类型的持久性后端。
我应该如何在我的存储库中结合“排序”和“过滤”?例如,考虑 列表的存储库。订购 项目。
(Query)findAllSortedByDate;
(Query)findAllSortedByName;
(Query)findAllSortedByQuantity;
最佳答案
在过滤
Fowler 所说的“类集合接口(interface)”并不是指暴露类似数组或列表的 API:它与 ICollection<T>
无关。 , 例如!存储库应该 encapsulate持久层的所有技术细节,但应该定义它的 API,以便它在业务领域中具有表现力。
您应该将规范视为与域相关的逻辑谓词(实际上它们是域模型中的一等公民),可以由 组成。检查实体的不同品质和 从集合中选择实体 (可以是存储库或简单列表的集合)。例如,在我为一家意大利银行设计的金融领域模型中,我有 DurationOfMBondSpecification
, StandardAndPoorsLongTermRatingSpecification
等等。
实际上,在 DDD 中,规范来自软件在其操作期间必须强制执行的业务需求(通常是契约(Contract)范围)。他们可以被用作过滤器的抽象,但这更像是一个幸运的副作用。
在排序
大多数时候排序(以及切片和分组......)只是一个演示问题。当它是一个业务问题时,正确的 比较器 (以及石斑鱼等)应该从领域专家的知识中提炼为领域概念。
然而,即使它只是一个演示问题,在存储库中处理它的效率要高得多。
在 .NET 上,解决这些问题的一种可能(并且非常昂贵)的方法是编写一个自定义 LINQ 提供程序(或多个),它可以翻译 全部 可以用通用语言表达的查询到所需的持久层。但是,如果您无法翻译 ,此解决方案有一个主要缺点。全部 从一开始的查询,您将永远无法估计使用域更改应用程序的工作量:您将不得不深度重构 QueryProvider 以处理新的复杂查询(并且这种重构将花费你比你负担得起的要多得多)。
为了解决这个问题,在(正在进行中且非常雄心勃勃)Epic框架(免责声明:我是核心开发人员),我们选择加入规范模式和查询对象模式,提供通用 API,使客户端能够根据规范进行过滤,使用比较器进行排序并使用整数进行切片,而无需(不可预测的)LINQ 成本。
在 Fowler 方案(如下)中,我们将规范(aCriteria)和辅助排序要求都传递给存储库:
作为替代方案,您可以使用 custom repositories :如果您没有数千种不同类型的查询,这是迄今为止更便宜的方法。
奖金解决方案
一个快速但仍然 正确 解决方案是“只”像查询一样使用您的持久性语言。 DDD 用于复杂的操作边界,查询(大多数时候)不起作用:因此您可以简单地使用 SQL 或 NoSQL 数据库提供的语言来检索您需要的投影和/或 identifiers您需要操纵的实体。您将看到您查询的数据集与确保域不变量所需的数据集有何不同!
这就是为什么,例如,有时,序列化文件可能是解决手头问题的域持久性的最佳方法。
毕竟,什么是文件系统,如果不是最广泛的 NoSQL 数据库 ! :-D
关于design-patterns - 规范模式和 DDD,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18185704/
这个问题在这里已经有了答案: Difference between / and /* in servlet mapping url pattern (5 个回答) 4年前关闭。 web.xml 中的/
Scala 具有支持模式匹配中析取的语言功能(“模式替代”): x match { case _: String | _: Int => case _ => } 但是,如果审查满足 P
解释我的问题: 类别:玩具 特质 1:说话像男性 特质2:说话像女性 我能否在运行时更改 Toy 的行为(特征),以便有时同一个对象说话像男性,有时同一个对象说话像女性? 我想在运行时改变说话行为。
我已经能够找到很好的资源,这些资源告诉我 Java API 中的 MouseAdapter 没有使用适配器模式。问题是:MouseAdapter 是否实现了某种模式? 我知道它的作用:它为 Mouse
我有兴趣了解有关模式识别的更多信息。我知道这是一个广泛的领域,所以我将列出一些我想学习处理的特定类型的问题: 在看似随机的字节集中查找模式。 识别图像中的已知形状(例如圆形和正方形)。 注意给定位置流
关闭。这个问题需要多问focused 。目前不接受答案。 想要改进此问题吗?更新问题,使其仅关注一个问题 editing this post . 已关闭 8 年前。 Improve this ques
所以,问题很简单:在 awk 中,if (var ~/pattern/) 是否与 if (var ~ "pattern") 相同? 我已经对 csv 进行了一些基本测试,两者似乎都产生了相同的结果..
我的问题是 this 的 Scala (Java) 变体Python 上的查询。 特别是,我有一个字符串 val myStr = "Shall we meet at, let's say, 8:45
我最近一直在研究正则表达式并注意到了这一点。 Pattern pNoEmbed = Pattern.compile("[ a-z]+", Pattern.CASE_INSENSITIVE); Patt
在研究大型应用程序的 C++ 源代码时,我发现了这种模式(该示例的语法可能很粗略,但基本细节都在那里): class A : X friend B; B *parent; ...
有人可以举一个“中介者模式”在现实世界中有用的用例吗? 最佳答案 Mediator是一种添加第三方对象以控制一组(2 个或更多)对象之间交互的方法。 您能找到的最简单的示例是 Chat Room例如,
尝试编译以下代码片段时: type 'a frame = Empty | Frame of string * 'a * 'a frame let rec searchFrame f s = match
目标 我的目标是获得一个 servlet 过滤器来处理对主页的请求,然后再将它们转发到 index.jsp。 问题 我无法让过滤器接收来自“/”的请求。它的 URL 模式是 / 相反,对该模式的请求最
这个问题已经有答案了: Difference between / and /* in servlet mapping url pattern (5 个回答) 已关闭 6 年前。 我已经设置了一个具有此
第 6 章(代码重用模式)中有以下示例: // the parent constructor function Parent(name) { this.name = name || 'Adam
Pattern类中的pattern()方法和toString()方法有什么区别? 文档说: public String pattern() Returns the regular expression
我有脚本 here并且 ng-pattern 工作正常,因为 scope.subnet 仅在输入匹配模式后才显示在输出中。但是如果 ng-pattern 不匹配,ng-show 不会显示任何错误
我想知道为什么当提供相同的正则表达式和相同的字符串时,java regex pattern.matcher() 和 pattern.matches() 的结果会不同 String str = "hel
This SO answer引用“患有模式综合症的小男孩”。虽然我可以通过上下文推断出一些含义,但我并不完全理解。 “有模式综合症的小男孩”的良好定义是什么? 最佳答案 它只是意味着寻找将模式注入(i
我有以下微服务架构的用例。 我的问题是,在当前情况下,我有 3 个微服务和一个 APIGateway。 最后,网关必须在聚合(组合)来自 3 个服务的数据之前进行大量查询。因为这 3 个微服务只提供基
我是一名优秀的程序员,十分优秀!