当前位置:  开发笔记 > 编程语言 > 正文

如何组织领域驱动的设计项目?

如何解决《如何组织领域驱动的设计项目?》经验,为你挑选了2个好方法。

我已经开始学习DDD,并想知道其他人如何组织他们的项目.

我开始组织我的AggregateRoots:

MyApp.Domain(域模型的命名空间)

MyApp.Domain.Product
- 产品
- IProductService
- IProductRepository
- 等

MyApp.Domain.Comment
- 评论
- ICommentService
- ICommentRepository
- 等

MyApp.Infrastructure
- ...

MyApp.Repositories
- ProductRepository:IProductRepository
- 等

我遇到的问题是我必须将我的域名产品称为MyApp.Domain.Product.Product或Product.Product.我也与产品的linq数据模型发生冲突....我必须使用丑陋的代码行来解析两者之间的问题,例如MyApp.Domain.Product.Product和MyApp.Respoitories.Product.

我真的很想知道其他人如何组织他们的DDD解决方案......

我使用Visual Studio作为我的IDE.

非常感谢.



1> Console..:

我尽量保持简单,所以通常这样的东西对我有用:

Myapp.Domain - 所有特定于域的类共享此命名空间

Myapp.Data - 从域中抽象数据库的精简层.

Myapp.Application - 所有"支持代码",日志记录,共享实用程序代码,服务使用者等

Myapp.Web - Web UI

所以类将是例如:

Myapp.Domain.Sales.Order

Myapp.Domain.Sales.Customer

Myapp.Domain.Pricelist

Myapp.Data.OrderManager

Myapp.Data.CustomerManager

Myapp.Application.Utils

Myapp.Application.CacheTools

等等.

我试图记住的想法是,"域"命名空间是捕获应用程序的实际逻辑的原因.那么你可以与"领域专家"(将使用该应用程序的家伙)谈论的内容是什么.如果我因为他们提到的东西而编码某些东西,它应该在域命名空间中,并且每当我编写他们未提及的东西(如日志记录,跟踪错误等)时,它不应该在域命名空间中.

因此,我也对制作过于复杂的对象层次结构持谨慎态度.理想情况下,非编码人员应该直观地理解域模型的简化图.

为此,我通常不会通过更详细地考虑模式来开始.我尝试按照标准的面向对象设计指南,尽可能简单地对域进行建模.什么需要成为一个对象?它们有什么关系?

在我看来,DDD是关于处理复杂的软件,但是如果你的软件本身并不复杂,那么你可能很容易陷入DDD做事方式而不是去除它的情况.

一旦你的模型中有一定程度的复杂性,你就会开始看到应该如何组织某些事情,然后你将知道使用哪些模式,哪些类是聚合等.

在我的示例中,Myapp.Domain.Sales.Order将是一个聚合根,因为它在实例化时可能包含其他对象,例如客户对象和订单行集合,并且您只能访问订单行对于通过订单对象的特定订单.

但是,为了简单起见,我不会有一个只包含其他所有内容且没有其他目的的"主"对象,因此订单类本身将具有在应用程序中有用的值和属性.

所以我会参考像:

Myapp.Domain.Sales.Order.TotalCost

Myapp.Domain.Sales.Order.OrderDate

Myapp.Domain.Sales.Order.Customer.PreferredInvoiceMethod

Myapp.Domain.Sales.Order.Customer.Address.Zip

等等



2> Bryan Watts..:

我喜欢在应用程序的根命名空间中拥有域,在自己的程序集中:

Acme.Core.dll[root namespace:Acme]

这整齐地表示域名在应用程序的所有其他部分的范围内.(有关更多信息,请参阅Jeffrey Palermo 撰写的洋葱建筑).

接下来,我有一个数据程序集(通常使用NHibernate)将域对象映射到数据库.该层实现了存储库和服务接口:

Acme.Data.dll[root namespace:Acme.Data]

然后,我有一个演示程序集,声明我的UI模式选择的元素:

Acme.Presentation.dll[root namespace:Acme.Presentation]

最后,还有UI项目(假设这里有一个Web应用程序).这是前面层中元素的组成发生的地方:

Acme.Web[root namespace:Acme.Web]

推荐阅读
携手相约幸福
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有