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

news2024/9/24 13:25:19

本篇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词汇表。一个比较深的体会是对于多对多关联拆分的考虑,例如业务事件阶段的【门店、合作】以领域名词的形式候选为实体,在领域建模阶段明确其多重性为多对多关系(一个合作可以有多个门店,附加时间维度一个门店不同时候也可以属于不同合作),但门店的合作包含其特有的合作周期和签约信息,这部分信息放到合作还是门店都不合适,于是需要增加关联实体【门店合作信息】将多对多关联拆分来记录关联特有的属性。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2074117.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Python优化算法14——海鸥优化算法(SOA)

科研里面优化算法都用的多,尤其是各种动物园里面的智能仿生优化算法,但是目前都是MATLAB的代码多,python几乎没有什么包,这次把优化算法系列的代码都从底层手写开始。 需要看以前的优化算法文章可以参考:Python优化算…

【图文并茂】ant design pro 如何给后端发送 json web token - 请求拦截器的使用

上一节有讲过 【图文并茂】ant design pro 如何对接后端个人信息接口 还差一个东西,去获取个人信息的时候,是要发送 token 的,不然会报 403. 就是说在你登录之后才去获得个人信息。这样后端才能知道是谁的信息。 token 就代码了某个人。 …

工作实战-项目压测记录

1-1-1每分钟的单量 1-1-2第二版测试 2022年5月16日 17:43:11 成功 失败 其它(nginx) 真实入库单量 总单量 52 1 447 500 2022年5月16日 19:42:18 成功 失败 其它(nginx) 真实入库单量 总单量 311 689 306 1000 2-0-1. 20线程-2000单执行结果 2-1-0. 40线…

金融科技 API 接口:提升金融服务效率的关键

金融科技是应用技术手段和创新理念来提升金融服务效率的重要途径。而其中的API接口则是实现金融科技的关键。API接口的简单定义是提供计算机程序之间通信的规范和工具,提供一种方法和数据的交互形式,以便开发人员能够利用现有的软件来创建新的应用和服务…

前端网格布局display: grid;

display: grid; 块级网格 (常用) display: inline-grid; 行内块级网格 (一般不用) HTML 元素将 display 属性设置为 grid 或 inline-grid 后,它就变成了一个网格容器,这个元素的所有直系子元素将…

Mobile-Agent项目部署与学习总结(DataWhale AI夏令营)

前言 你好,我是GISer Liu,一名热爱AI技术的GIS开发者,本文是DataWhale 2024 AI夏令营的最后一期——Mobile-Agent赛道,这是作者的学习文档,这里总结一下,和作者一起学习这个多模态大模型新项目吧&#x1f6…

开放式耳机对耳朵的伤害会减小吗?亲测好用的四款蓝牙耳机

开放式耳机对耳朵的伤害相对较小。 首先,开放式耳机不入耳,不会直接堵塞耳道,减少了对耳道的挤压和摩擦,降低了因长期佩戴入耳式耳机可能导致的耳道发炎、疼痛等问题。 其次,由于耳朵没有被完全封闭,耳部能…

【C/C++】结构体指针赋值的方法

在C语言中,结构体指针赋值有两种方法: 1.使用"->"操作符:通过结构体指针访问结构体成员并赋值。例如: struct Student {int id;char name[20]; };int main() {struct Student s1;struct Student *ptr_s1 &s1;…

设计模式学习[4]---依赖倒置原则+里氏代换原则

文章目录 前言1. 依赖倒置原则1.1 原理阐述1.2 举例 2.里氏代换原则2.1 原理阐述2.2 举例说明 总结 前言 在给发新功能模块之前,都先要画UML类图进行需求分析。对每一个类的作用,类与类之间的关系做一个详细的阐述。确定好基本的框架之后,才…

Lumos学习王佩丰Excel第十四讲:日期函数

一、认识时间和日期 1、回顾日期格式 日期可以由数字表示。 2、时间格式 时间由小数表示。 3、基本的时间与日期运算 二、日期函数 1、Year、Month、Day函数 2、Date函数 DATE(year,month,day):year为必需参数,可以包含1到4个数字。Day函…

LeetCode 热题 100 回顾

目录 一、哈希部分 1.两数之和 (简单) 2.字母异位词分组 (中等) 3.最长连续序列 (中等) 二、双指针部分 4.移动零 (简单) 5.盛最多水的容器 (中等) 6…

文心一言 VS 讯飞星火 VS chatgpt (332)-- 算法导论23.1 1题

一、设(u,v)是连通图G中的一条权重最小的边,证明:边(u,v)为图G的某棵最小生成树中的一条边。如果要写代码,请用go语言。 文心一言: 为了证明边(u,v)是图G的某棵最小生成树中的一条边,我们可以使用反证法结合最小生成…

09 复合查询

前面的查询都是对一张表进行查询,但这远远不够 基本查询回顾 查询工资高于500或岗位为MANAGER的雇员,同时还要满足他们的姓名首字母为大写的J select * from EMP where (sal>500 or job‘MANAGER’) and ename like ‘J%’; 按照部门号升序而雇员的…

免费用的写作神器:一键自动生成文章,提升内容创作效率!

传统的写作过程往往耗时耗力,从构思、调研到撰写、修改,每一步都需要创作者亲力亲为。免费写作神器的出现,犹如一场及时雨,为创作者提供了强大的支持。它利用先进的算法和自然语言处理技术,能够在短时间内生成高质量的…

了解Redis数据持久化(中)

3.5写时复制 Redis在使用RDB方式进行持久化时,会用到写时复制机制。写时复制的效果: bgsave子进程相当于复制了原始数据,而主线程仍然可以修改原来的数据。 对Redis来说,主线程fork出bgsave子进程后,bgsave子进程实际是复制了主线…

初识C语言指针(5)

目录 1. 回调函数 2. qsort函数 2.1 qsort函数的基本参数 2.2 qsort函数的使用 2.3 qsort排序结构体类型数据 结语 1. 回调函数 什么是回调函数呢?回调函数就是⼀个通过函数指针调⽤的函数。 如果你把函数的指针(地址)作为参数传递给另…

超分CAMixerSR 使用笔记

目录 超分CAMixerSR 笔记 自己改进的图例示例: 修改目录: 设置预训练模型: 超分CAMixerSR 笔记 自己改进的图例示例: 修改目录: codes/basicsr改为codes/basicsr_m 设置预训练模型: path:pretrain_network_g: F:\project\chaofen\CAMixerSR-main\pretrained_mode…

解决html中文乱码问题

在head上面添加 <% page contentType"text/html;charsetUTF-8" language"java" %>

【Three.js基础学习】19.Custom models with Blender

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 前言 blender模型资源:【blender】一个汉堡包-CSDN博客 一、代码 import ./style.css import * as THREE from three import { OrbitControls } from three/examples/jsm/co…

集成mybatis-plus框架

文章目录 1.新建一个sun_frame数据库并创建user表2.新建一个sun-common-mybatisplus模块1.maven项目2.添加依赖 3.sun-user集成mybatis-plus1.配置application.yml2.修改架构&#xff0c;由sun-user模块引入需要的公共模块3.代码目录结构4.mapper&#xff1a;po查&#xff0c;p…