- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
有争议的讨论Repositories ,它们在 stackoverflow 和整个网络上的使用和布局。我对如何有效地实现存储库背后的数据访问抽象(例如数据库)感到困惑。
我没有使用 ORM 工具/框架,因为我想自己查看详细信息。目前我正在使用 DAO 对象访问 (mysql) 数据库并提供业务对象(域对象)。数据库表中外键给出的关联在相应对象的 DAO 中解析和加载(目前没有延迟加载)。因为我不想在业务逻辑中直接使用我的数据库 DAO,所以我认为存储库是一个很好的进一步抽象。在 Repository 中实现诸如 GetEmployeesByShopAndPosition() 之类的复杂查询时,我遇到了困难:我看到了实现它的两种可能性:
第一种方法使用了 Repository 实际上应该具有的集合性质,但似乎效率很低。第二种方法生成 bloated DAO但效率更高。
我的问题:
我知道这个主题不是非黑即白的,因为所涉及的设计模式也可以用不同的方式实现,但我想有些指导方针不应该被打破或混淆以获得关注点分离和持久性无知 (PI) .
最佳答案
你实际上在这里问了很多问题,所以我会尽量让答案尽可能简洁:)
存储库返回一个聚合根
或一个实体
。有些人非常坚持存储库只返回 AR,这很好并且总是足够的。
有两种类型的存储库(Vaughn Vernon 在他的实现领域驱动设计一书中对此进行了很好的描述):
您可能会更频繁地遇到并使用面向持久性的方法。这可能是 w.r.t. 引起混淆的地方。道。当然,DAO 可能会返回一个业务对象,但它可能会返回更多。
您的查询 示例是 DAO 可能更合适的地方。因此,在领域驱动设计领域中,您会经常遇到 CQRS(命令/查询责任分离)。归结为不查询您的域。
您应该有一个薄的、专用的查询层,它以最合适的格式(但不是实体)返回结果。在 c# 中,我使用诸如 DataTable
、DataRow
、string
之类的东西,如果需要,有时还使用复杂的 DTO。
存储库只关心 AR,例如:
存储库基本上使用各种逻辑 DAO(ADO.NET、ORM --- 我尽量避免使用 ORM)。
关于使用关联的外键检索 AR 的第二点:AR 应该绝不包含对另一个 AR 的引用。实体和 Value Objects
都可以。对于关联的 AR,使用 ID 或值对象来表示外部 AR。 AR 本身可能包含一个复杂的结构,但不要混淆所有权和包含。 OrderLine
包含在 Order
中。一个 Customer
拥有一个 Order
。所以 Order
将有一个 OrderLine
集合,但不是对 Customer
对象(而是 ID/VO)的引用。
Order
/OrderLine
示例说明了为什么我们不查询域。当我们想要给定开始日期和结束日期之间的订单列表时,我们可能对所有订单数据都不感兴趣,当然也不会对订单行感兴趣。所以加载这些聚合没有意义。这就是在查询域时,像延迟加载这样令人讨厌的事情会出现的地方。恕我直言,延迟加载不应该存在 :) --- 一个简单的查询层就足够了。
希望对您有所帮助。
关于domain-driven-design - DDD 存储库 : Use DAO for separation?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28137760/
这个问题在这里已经有了答案: Joining elements of a list in GNU Make (3 个回答) 2年前关闭。 我有这个: FOO = foo1 foo2 ... fooN
我们有两种产品在客户现场实现,其中一个需要另一个在场。我在与附加组件所需的数据库对象的主要产品相同的数据库中实现了一个单独的模式。因为该附加组件理论上也可以成为 future 产品的附加组件(尽管目前
它的作用:这是一个 Android 应用程序,将模仿我的团队正在创建的网站 apdata.info。这是第二页,它将显示符合他们请求的搜索的机场。 PHP ... $sql = "SELECT apn
我在 Angular 4 中使用 slider 。下面是我的 HTML 代码: Actual/Optimised
Linux RHEL5 机器 如何对以下输入进行排序以在 latest 变量中获取 1.0.0.1019?尝试了 -t、-k 和 -n 但没有帮助,或者可能是我遗漏了什么。 $ echo '1.0.0
因此,我有一个值为“app、beta、theta”的单元格,我想查看填充有上述单元格的列是否包含我的单元格值。例如:AA 列有这些单元格:“app”; “theta,应用程序”; “theta,app
我想读取一个包含多个(未终止的)Kafka 主机的字符串,并使用 cmd for 将它们列出在单独的行中。 字符串如下: host1:9092,host2:9092,host3:9092,... 我所
我突然想到,例如,假设我们有二维 N 点的训练数据。我们知道我们总是可以天真地构建一个决策树,以便我们可以对每个数据点进行分类。 (可能我们过拟合了,深度可以到2N) 但是,我们知道如果数据集是线性可
我知道这是一件奇怪的事情,但现在我正在构建一个测试项目,并且我将正在测试的应用程序的几个区域/容器分开在不同的类中,如保持组织的措施。因此,如果我想将一个元素从区域 A 拖动到区域 B,我必须将 D&
你好, 在编写 XSLT 样式表时,我遇到了一个无法解决的问题。我的基本 XML 结构如下 我想打印所有列的名称。因此,我使用了以下语句(我正在遍历所有 nonUniqueConstr
单一职责原则和关注点分离有什么区别? 最佳答案 Single Responsibility Principle (SRP)- give each class just one reason to ch
如何获取指定文件/文件夹路径的文件分隔符? 在Java中,我们可以这样写 File f = new File("C:\\MyFolder\\MyText.txt"); 请记住,这是一种文件表示(该文件
我正在开始开发一个新程序(用于学校项目),其中用户登录并有一个类似“时间线”的页面。目前它是一个简单的命令行 C 项目。 我想通过以下方式将数据存储在文本文件中: # Message here
我正在将 UIView(作为容器 View )添加到 UITableViewController。出于某种原因,UITableView 分隔符通过 UIView 可见。我运行的是 iOS 7。 UIV
产品代码在 UNIX 上运行,但需要在 Windows 上运行本地 DEV。 当前代码从数据库获取 UNIX 格式的路径,然后使用 file.separator 在该路径上构建,它添加了窗口分隔符,导
我正在使用 Eclipse 和本地服务器(如 XAMPP)在 Windows 中开发我的企业应用程序项目。 要从文件系统(部署文件夹外部)加载配置,我使用: String dataOrdner = S
我刚刚使用 iTextSharp 从 pdf 中获取所有文本,现在我需要将该文本拆分为单词。我以前使用 Acrobat 库,它会自动将它分成单词(使用 getPageNthWord())。 我不知道使
在WPF的集合控件中常常需要在每一个集合项之间插入一个分隔符样式,但是WPF的ItemsControl没有相关功能的直接实现,所以只能考虑曲线救国,经过研究,大概想到了以下两种实现方式。 先写出I
出现如下错误 Groovy script throws an exception of type class java.util.regex.PatternSyntaxException with m
请问有没有语法来分隔“for”标签中的某些元素? 例如我有一个用户列表,我想用“-”分隔符显示他们的用户名,所以预期的结果是:Mickael - Dave - Chris - ... 我找到了这个解决
我是一名优秀的程序员,十分优秀!