- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
随着我对领域驱动设计的理解,我发现我有一个似乎有效的规则,尽管我想看看它是否过分杀伤力,也想看看相同情况的其他观点。
我的问题是:“域模型和持久性模型什么时候应该包含在单独的对象中?”我目前选择的语言是 Java,我正在使用 Spring Data 的存储库模型。
我看到了我的问题的三个主要答案。
为了提出有关 DDD 的问题,我发现我必须使用示例限界上下文,因为我对 DDD 的了解还不够多,无法以更抽象的方式提出问题。
这是我的说明性限界上下文:假设我有一个具有以下业务规则的法律编纂系统:
为了将此限界上下文表达为持久性模型,我有以下内容:
table: codification
fields: chart_code, prefix, coassign, codification_category
table: codification_chart
fields: chart_code, jurisdiction_description
table: codification_category
fields: category, low_category_number, high_category_number, description
table: global_codification
fields: prefix, coassign, codification_category
我知道,我应该首先从领域模型开始。我有一个持久化模型和一个域模型
在我的领域模型中,我有三个领域对象
public Codification {
private String prefix, coassign;
codificationCategory codificationCaegory; // an enum type
public Codification(...) { // set private vars }
// getters for private variables
}
public CodificationChart {
private List<Codification> chartCodifications = new ArrayList<>();
private String chartCode;
// public constructor to initialize private variables
// getters for private variables
public Codification addCodificationToChart(Codification){...}
public void removeCodificationFromChart(Codification){...}
public boolean checkCodificationInChart(Codification){...}
}
public enum CodificationCategory {
CIVIL, CRIMINAL, PROPERTY, CORPORATE, FAMILY, CONSUMER, ETHICS, BANKRUPTCY;
}
ORM 对象:
JPA Mappings of the tables mentioned earlier with the "Entity" suffix added to their table names.
They are omitted for brevity.
Each one contains getters and setters like JPA Pojos do.
If someone asks for the Persistence objects code I will post it.
我的域对象知道持久性模型的唯一点是在我的工厂对象 CodificationChartFactory
中,它具有我用来与前面提到的 ORM 对象交互的存储库接口(interface)。该工厂是域中唯一使用持久性存储库的部分,因此也是唯一与持久层交互的部分。
在这里创建一个单独的领域模型是在浪费精力吗?我可以看到如何将我的 CodificationChart 行为放在 Persistence 对象上。将这些行为放在唯一的工作就是从数据库中检索记录的持久性对象上感觉有点不对。
我绝对愿意接受纠正。
最佳答案
这两种方法都是正确的,并且从设计的角度来看是一种品味问题。有些人不希望他们的域对象与持久性有任何关系,而是创建一个额外的 Entity
对象层......有些人认为这不是主要问题并且很高兴继续使用域对象作为持久性对象。
就我个人(和主观)而言,我认为使用 JPA 并拥有一个额外的 Entity 对象层是错误的方法。像 Hibernate 这样的 ORM 的目标是成为对象和关系模型之间的桥梁(我知道它的名字:)。我认为一种更好的方法是使用 mybatis 或纯 SQL 之类的方法,但绝对不是 JPA...否则它只是为了增加复杂性复杂性(JPA 不是最容易学习的框架)
我很乐意混合使用并注释我的域对象。据我所知,它使持久性更易于管理……但与此同时,我对 Hibernate/JPA 感到非常满意并且已经使用了 10 年:)。
3 年前我有一个非常相似的问题,我将其发布在程序员网站上 - Do ORMs enable the creation of rich domain models?
关于java - DDD 什么时候应该创建域对象和持久化对象而不是将持久化对象用作域对象?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33268944/
我是 python 的新手。我试图找到我的文本的频率分布。这是代码, import nltk nltk.download() import os os.getcwd() text_file=open(
我对安卓 fragment 感到困惑。我知道内存 fragment 但无法理解什么是 android fragment 问题。虽然我发现很多定义,比如 Android fragmentation re
尝试对 WordPress 进行 dockerise 我发现了这个场景: 2个数据卷容器,一个用于数据库(bbdd),另一个用于wordpress文件(wordpress): sudo docker
这个问题已经有答案了: From the server is there a way to know that my page is being loaded in an Iframe (1 个回答)
我正在玩小型服务器,试图对运行在其上的服务进行docker化。为简化起见,假设我必须主要处理:Wordpress和另一项服务。 在Docker集线器上有许多用于Wordpress的图像,但是它们似乎都
我想要发生的是,当帐户成功创建后,提交的表单应该消失,并且应该出现一条消息(取决于注册的状态)。 如果成功,他们应该会看到一个简单的“谢谢。请检查您的电子邮件。” 如果不是,那么他们应该会看到一条适当
就是这样,我需要为客户添加一个唯一标识符。通过 strip 元数据。这就是我现在完全构建它的方式,但是我只有最后一部分告诉我用户购买了哪个包。 我试着看这里: Plans to stripe 代码在这
我有一个类将执行一些复杂的操作,涉及像这样的一些计算: public class ComplexAction { public void someAction(String parameter
这个问题已经有答案了: maven add a local classes directory to module's classpath (1 个回答) 已关闭10 年前。 我有一些不应更改的旧 E
我使用 fragment 已经有一段时间了,但我经常遇到一个让我烦恼的问题。 fragment 有时会相互吸引。现在,我设法为此隔离了一个用例,它是这样的: Add fragment A(也使用 ad
我的 html 中有一个 ol 列表,上面有行条纹。看起来行条纹是从数字后面开始的。有没有办法让行条纹从数字开始? 我已经包含了正在发生的事情的片段 h4:nth-child(even) {
如何仅使用 css 将附加图像 html 化? 如果用纯 css 做不到,那我怎么能至少用一个图像来做 最佳答案 这不是真正的问题,而是您希望我们为您编写代码。我建议您搜索“css breadcrum
以下是 Joshua 的 Effective Java 的摘录: If you do synchronize your class internally, you can use various te
在这里工作时,我们有一个框向业务合作伙伴提供 XML 提要。对我们的提要的请求是通过指定查询字符串参数和值来定制的。其中一些参数是必需的,但很多不是。 例如,我们要求所有请求都指定一个 GUID 来标
我有 3 个缓冲区,其中包含在 32 位处理器上运行的 R、G、B 位数据。 我需要按以下方式组合三个字节: R[0] = 0b r1r2r3r4r5r6r7r8 G[0] = 0b g1g2g3g4
我最近发现了关于如何使用 History.js、jQuery 和 ScrollTo 通过 HTML5 History API 对网站进行 Ajax 化的要点:https://github.com/br
我们有一个 Spring Boot 应用程序,由于集成需要,它变得越来越复杂——比如在你这样做之后发送一封电子邮件,或者在你之后广播一条 jms 消息等等。在寻找一些更高级别的抽象时,我遇到了 apa
我正在尝试首次实施Google Pay。我面临如何指定gateway和gatewayMarchantId的挑战。 我所拥有的是google console帐户,不知道在哪里可以找到此信息。 priva
昨天下午 3 点左右,我为两个想要从一个 Azure 帐户转移到另一个帐户的网站设置了 awverify 记录。到当天结束时,Azure 仍然不允许我添加域,所以我赌了一把,将域和 www 子域重新指
我正在使用terms facet在elasticsearch服务器中获取顶级terms。现在,我的标签"indian-government"不被视为一个标签。将其视为"indian" "governm
我是一名优秀的程序员,十分优秀!