【领域驱动设计 打通DDD最小闭环】领域建模

2024-08-26 00:12

本文主要是介绍【领域驱动设计 打通DDD最小闭环】领域建模,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

本篇BLOG为DDD流程的第二步,在模型的建立阶段,领域专家与技术人员通过领域建模来完成更为细致的模型建立讨论
在这里插入图片描述

领域建模的目的

领域建模主要有两个目的:

  • 将知识可视化,准确、深刻地反映领域知识,并且在业务和技术人员之间达成一致
  • 指导系统的设计和编码,也就是说,领域模型应该能够比较容易地转化成数据库模式和代码实现

不同于事件风暴仅仅追求“形似”,也就是说业务是怎样运作的,事件风暴就怎样反映,领域建模更要“神似”。也就是说,领域建模不仅要对业务进行直观模拟,更要经过提炼,形成浓缩的知识,使模型中的知识不再停留在业务的表面,而是深入到业务的本质,进而加入技术视角选择最合适的建模方案

领域建模的步骤

我们建立领域模型,主要是要识别领域对象(domain object),领域对象之间的关系,以及领域对象的关键属性,必要的时候还要将领域对象组织成模块

1 识别领域对象

什么是领域对象,我们系统中要处理的各种“事物”就是领域对象(可能是领域名词,也可能是名词化的动词)DDD 中将领域对象又分成实体(entity)和值对象(value object)
在这里插入图片描述
我们可以先假定每个领域名词都是一个实体,把它们用UML图的类的符号画出来,例如
在这里插入图片描述

实体识别注意事项

实体的识别过程中有两点需要注意一下:

  • 领域建模阶段,我们主要关注的是实体和它们之间的关系,所以先不具体描述属性
  • 通过后序分析,我们会进一步识别有些名词不是实体,有些要转换成其他形式

也就是用领域名词来当做实体是第一步。

2 识别领域对象关系

领域对象中的关系主要有如下几种:一对一关系,一对多关系,多对多关系,并应用UML的一些表达技巧将这些关系表示出来,业务事件风暴后我们最终形成了如下的领域对象关系UML,这里有很多要点。
在这里插入图片描述

实体抽象【技巧】

企业、开发中心、开发组、直属部门,其实都是组织结构中的节点而已,从这一点来说,他们是有共性的,都是组织,所以可以抽象为组织和组织类别两个实体,同样管理员、人事人员的共性都是人员,所以可以抽象为人员和岗位两个实体,用于更灵活的扩展

注释与约束【标记】

可以通过增加注释和约束,使模型中的业务知识更加丰富和准确。其中,约束是一种特殊的注释,它的内容必须以某种形式在代码或数据库中实现。约束也属于我们在之前说的业务规则,需要补充到业务规则表中去
在这里插入图片描述

  • 在 UML 中,注释用折角的矩形表示,和被注释的实体之间用虚线连接
  • 约束的内容用大括号括起来了。在 UML 中,用大括号括起来的内容称为“约束”(constraint)

实体自关联【标记】

一个组织可以有多个组织作为自己的下级;而一个组织只能有一个组织作为自己的上级,在这个自关联的两端,有上级和下级两个词。它们在 UML 里称为“角色”(role),没有角色我们无法明确上下级的多重性
在这里插入图片描述

关联多重性【标记】

关联多重性主要表示两个实体之间的数量对应关系,我们通常会更细化一些,例如:
在这里插入图片描述

  • 0..1表示:一个下级可以没有上级,最多只能有一个上级
  • 1..1表示,一个员工最少要属于一个组织,最多也只能属于一个组织
  • 0..*表示:一个组织最少有 0 个员工,最多可以有很多员工

识别操作【标记】

操作(operation)在 UML 里也叫方法(method)。对象的属性是静态的值,而操作是动态的逻辑。在 UML 中,操作用“操作名 + 括号”的方式表示,括号中可以写参数
在这里插入图片描述

实体多关联【标记】

两个实体之间,可以有多个关联。不同的关联代表不同含义,数量关系也可以不同,可以用角色名来区分
在这里插入图片描述

  • 员工与项目的多对多关系:一个员工(角色为项目成员)可以被分配到多个项目上,一个项目上又可以有多个员工
  • 员工与项目的一对多关系:一个员工(角色为项目经理)可以被分配到多个项目上,一个项目只能有一个项目经理

拆分多对多关联【技巧】

某些情况下我们需要拆分多对多关联为两个一对多关联,一般有如下三种情况:

  1. 关联实体自身也有值得关注的属性【store_with_coop】 商户中的各种实体关系表设计的考虑,独有的包括关系的建立时间、断开时间,关系的状态等
  2. 关联实体本身也有业务关注的独立的含义的时候(常常表现为在业务的术语里面有)
  3. 多对多关系存在业务规则时,需要拆分出来一个承载的关联实体

例如项目管理有一个关于投入百分比的规则,那么投入百分比(关联实体自身的属性)这个属性应该记录在哪个实体上呢?这个百分比既不能记录在员工实体上,也不能记录在项目实体上
在这里插入图片描述
于是原来的项目成员角色演变成了一个独立的实体,来表达员工和项目之间的多对多关联。预计投入百分比也就自然放在这个实体里面了。注意,这时候,员工和项目成员之间的关联是一对多,项目和项目成员之间也是一对多。

3 将领域对象划分模块

当实体和关联复杂化后,就会让我们的认知过载,解决这一问题的方法就是“模块化”。也就是说,把模型中的业务概念组织成若干高内聚的模块(module),而模块之间尽量低耦合,在 UML 中,可以用包来表示模块,包的内部可以包含实体,也可以包含另外的包
在这里插入图片描述
宏观层面我们可以明确大致包间的依赖关系,在 UML 中带箭头的虚线表示依赖(dependency)关系,箭头由依赖方指向被依赖方,例如项目管理依赖组织管理
在这里插入图片描述

领域建模的产出

领域建模的产物主要有两个,一个是统一语言词汇表,一个是事件风暴时的业务规则表的继续完善。

UL词汇表

把事件风暴和领域模型中重要的词汇列成表,这么做主要有两个目的:

  • 我们需要通过词汇表来规范领域模型中的词汇
  • 可以用于后续编程中的命名。按照 DDD 的要求,程序中的各种命名也需要统一,并且需要与领域模型中保持一致
    在这里插入图片描述

业务规则表

我们在做事件风暴时就开始识别业务规则了,在领域建模中又识别出了更多的规则,所以现在我们需要把这些规则补充到业务规则表
在这里插入图片描述

总结一下

同事件风暴一样领域建模也是在模型建立阶段,但更进一步的,领域建模不仅要对业务进行直观模拟,更要经过提炼,形成浓缩的知识,使模型中的知识不再停留在业务的表面,而是深入到业务的本质,进而加入技术视角选择最合适的建模方案。可以理解为是对事件风暴的技术性加工,使用UML图的一些标记例如:注释、约束、多重性、自关联、多关联、角色以及一些技巧如:多对多关联拆分、抽象化实体、模块化来进行领域建模。最后完善业务规则表建立UL词汇表。一个比较深的体会是对于多对多关联拆分的考虑,例如业务事件阶段的【门店、合作】以领域名词的形式候选为实体,在领域建模阶段明确其多重性为多对多关系(一个合作可以有多个门店,附加时间维度一个门店不同时候也可以属于不同合作),但门店的合作包含其特有的合作周期和签约信息,这部分信息放到合作还是门店都不合适,于是需要增加关联实体【门店合作信息】将多对多关联拆分来记录关联特有的属性。

这篇关于【领域驱动设计 打通DDD最小闭环】领域建模的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1107005

相关文章

Python中的可视化设计与UI界面实现

《Python中的可视化设计与UI界面实现》本文介绍了如何使用Python创建用户界面(UI),包括使用Tkinter、PyQt、Kivy等库进行基本窗口、动态图表和动画效果的实现,通过示例代码,展示... 目录从像素到界面:python带你玩转UI设计示例:使用Tkinter创建一个简单的窗口绘图魔法:用

不懂推荐算法也能设计推荐系统

本文以商业化应用推荐为例,告诉我们不懂推荐算法的产品,也能从产品侧出发, 设计出一款不错的推荐系统。 相信很多新手产品,看到算法二字,多是懵圈的。 什么排序算法、最短路径等都是相对传统的算法(注:传统是指科班出身的产品都会接触过)。但对于推荐算法,多数产品对着网上搜到的资源,都会无从下手。特别当某些推荐算法 和 “AI”扯上关系后,更是加大了理解的难度。 但,不了解推荐算法,就无法做推荐系

poj 1258 Agri-Net(最小生成树模板代码)

感觉用这题来当模板更适合。 题意就是给你邻接矩阵求最小生成树啦。~ prim代码:效率很高。172k...0ms。 #include<stdio.h>#include<algorithm>using namespace std;const int MaxN = 101;const int INF = 0x3f3f3f3f;int g[MaxN][MaxN];int n

poj 1287 Networking(prim or kruscal最小生成树)

题意给你点与点间距离,求最小生成树。 注意点是,两点之间可能有不同的路,输入的时候选择最小的,和之前有道最短路WA的题目类似。 prim代码: #include<stdio.h>const int MaxN = 51;const int INF = 0x3f3f3f3f;int g[MaxN][MaxN];int P;int prim(){bool vis[MaxN];

poj 2349 Arctic Network uva 10369(prim or kruscal最小生成树)

题目很麻烦,因为不熟悉最小生成树的算法调试了好久。 感觉网上的题目解释都没说得很清楚,不适合新手。自己写一个。 题意:给你点的坐标,然后两点间可以有两种方式来通信:第一种是卫星通信,第二种是无线电通信。 卫星通信:任何两个有卫星频道的点间都可以直接建立连接,与点间的距离无关; 无线电通信:两个点之间的距离不能超过D,无线电收发器的功率越大,D越大,越昂贵。 计算无线电收发器D

poj 1734 (floyd求最小环并打印路径)

题意: 求图中的一个最小环,并打印路径。 解析: ans 保存最小环长度。 一直wa,最后终于找到原因,inf开太大爆掉了。。。 虽然0x3f3f3f3f用memset好用,但是还是有局限性。 代码: #include <iostream>#include <cstdio>#include <cstdlib>#include <algorithm>#incl

hdu 1102 uva 10397(最小生成树prim)

hdu 1102: 题意: 给一个邻接矩阵,给一些村庄间已经修的路,问最小生成树。 解析: 把已经修的路的权值改为0,套个prim()。 注意prim 最外层循坏为n-1。 代码: #include <iostream>#include <cstdio>#include <cstdlib>#include <algorithm>#include <cstri

怎么让1台电脑共享给7人同时流畅设计

在当今的创意设计与数字内容生产领域,图形工作站以其强大的计算能力、专业的图形处理能力和稳定的系统性能,成为了众多设计师、动画师、视频编辑师等创意工作者的必备工具。 设计团队面临资源有限,比如只有一台高性能电脑时,如何高效地让七人同时流畅地进行设计工作,便成为了一个亟待解决的问题。 一、硬件升级与配置 1.高性能处理器(CPU):选择多核、高线程的处理器,例如Intel的至强系列或AMD的Ry

Linux_kernel驱动开发11

一、改回nfs方式挂载根文件系统         在产品将要上线之前,需要制作不同类型格式的根文件系统         在产品研发阶段,我们还是需要使用nfs的方式挂载根文件系统         优点:可以直接在上位机中修改文件系统内容,延长EMMC的寿命         【1】重启上位机nfs服务         sudo service nfs-kernel-server resta

poj 2175 最小费用最大流TLE

题意: 一条街上有n个大楼,坐标为xi,yi,bi个人在里面工作。 然后防空洞的坐标为pj,qj,可以容纳cj个人。 从大楼i中的人到防空洞j去避难所需的时间为 abs(xi - pi) + (yi - qi) + 1。 现在设计了一个避难计划,指定从大楼i到防空洞j避难的人数 eij。 判断如果按照原计划进行,所有人避难所用的时间总和是不是最小的。 若是,输出“OPETIMAL",若