领域建模:分清问题域和问题解决域(下)

简介: 领域建模:分清问题域和问题解决域(下)

领域模型=ER?


领域模型是否就是ER模型呢?答案是否定的,领域模型是特定业务域业务实体关系的自然浮现,而ER是设计阶段数据库实现关系的产物。


如下图所示,自然人Person在特定业务领域有2类,一类是客户(Customer),一类是雇员(Employee).


微信图片_20220121143502.jpg


但究其实现而言,数据库设计有多种形态。


微信图片_20220121143522.jpg


微信图片_20220121143526.jpg


微信图片_20220121143529.jpg



领域建模=DDD?


一说领域建模就提及DDD, 是大家的自然反应。因为DDD(2004年著名建模专家EricEvans发表了他最具影响力的著名书籍:Domain-Driven Design –TacklingComplexity in the Heart of Software)的知名度颇高。我的观点是领域模型的产生是分析阶段的产品,分析是对需求及需求背后相关内容的挖掘,不用创造内容。DDD顾名思义是模型驱动设计,是从需求打通到设计阶段的方法。


领域建模涉及到哪些概念呢?


域(domain):需要讨论的问题范围,称为域或者问题域。


子域(subdomain)对于域进行不同纬度切分相对内聚的单元。比如电商业务涉及订单、库存、营销子域等。


语境(context)是一个特定人群在讨论的问题域是所形成的上下文。 这里要强调一个概念,特定人群不是以团队或者是项目为边界划分的人群, 而是以知识为边界来划分的人群。 也就是说上下文不是普遍存在的, 而是存在于一个人群内部的,并且这些上下文大多是以隐形知识(Tacit Knowledge)的方式而存在的。


域语言(Ubiquitous  Language): 领域模型可以成为大家沟通公共语言的核心,同时将团队沟通与软件实现紧密联系到一起。这种公共语言是整个团队工作中的UBIQUITOUS LANGUAGE(通用语言)。


实体(Entity)实体就是领域中需要唯一标识的领域概念。因为我们有时需要区分是哪个实体。有两个实体,如果唯一标识不一样,那么即便实体的其他所有属性都一样,我们也认为他们两个不同的实体;因为实体有生命周期,实体从被创建后可能会被持久化到数据库,然后某个时候又会被取出来。所以,如果我们不为实体定义一种可以唯一区分的标识,那我们就无法区分到底是这个实体还是哪个实体。


数值对象(Value Object) 值对象没有唯一标识,这是它和实体的最大不同。有一部电影中说联邦调查局通过隐私查询,查询到男主和女二曾在大学期间拥有相同的收货地址而判断他们曾住在一起。这里的Address可以作为值对象,它的所有属性决定它是谁,而不必通过ID来区别。


触发事件(Event)企业级应用程序事件大致可以分为三类:系统事件、应用事件和领域事件。领域事件的触发点在领域模型(Domain Model)中,故以此得名。通过使用领域事件,我们可以实现领域模型对象状态的异步更新、外部系统接口的委托调用,以及通过事件派发机制实现系统集成。在系统分析阶段,我的观点是不区分事件类型。


思考 Event与彩色建模中的MI有无区别和联系?


在电信信息架构中有大量的事件,如下图所示。


微信图片_20220121143602.jpg


观点:不建议在分析阶段区别Entity和Value Object

不建议在分析阶段区别Entity和Value Object。比如Customer和Adress的关系和区别一样,在后续精细化过程中,认识自然就清楚了,比如Adress是可以复用的,非唯一的。

观点:在域模型中可以增加业务规则作为补充

在域模型中可以增加业务规则作为补充。比如下图在送货单和订单项的关系上有一行约束说明:只有当所有订单项都已经送到,才能成功关闭订单。


微信图片_20220121143628.jpg


我们来看看 DDD的内容那些是领域建模(分析阶段应该识别的)。


微信图片_20220121143640.jpg


如上图所示,在分析阶段可以用的至多有entity、value object。再次论证了DDD是一个重在Design的工具。


基于上面域,域语言等概念,不难理解不同域同一名词的含义不同,即使是同一介质它的内涵和外延也不同,我们可以把域表述为问题域。

比如电子商务网站有优惠券,包括天猫购物券、店铺券、商品优惠券等,下图为淘宝券截图。



微信图片_20220121143656.jpg

还有一个专门做券导航的网站:券妈妈。



微信图片_20220121143710.jpg


这2个网站管理的券是同类的东西,它们的模型是否就一样了呢?这2个网站管理的都是券,但是业务实体[券]是有差异的,因为它们要解决的问题域不同。券妈妈是一个流量入口,关注领用和跳转;而淘宝券关注使用情况[下单时订单金额扣减],包括使用券的用户对店铺的黏性,二次消费等。业务实体的业务行为,状态也有有所差异。


问题域vs问题解决域


最后总结一下,问题域和问题解决域是2个范畴,分属分析、设计及实现阶段,在不同阶段使用的工具和目标也有所差异,如下图所示:


微信图片_20220121143725.jpg


在分析阶段的领域模型中,我觉得主要描述领域实体及关系,可以辅助领域名词解释(可以是业务字典形式)、以及约束(业务规则),而业务实体(域实体)仅描述主特征即可。


微信图片_20220121143738.jpg


未完待续,领域建模刍议(二)将介绍建模的方法体系。


ps: 系统化思考是最好的总结和学习,我在编写本章的过程中发现了一些模糊的内容,包括写完也有不少未知。

ps:长期使用java语言,近几个月发现.net领域不乏对于领域的深入思考者。


特别推荐:

汤雪华,网名netfocus,2006年毕业于浙江大学,目前住在杭州。对DDD,以及CQRS架构比较感兴趣。开源软件ENode负责人,现就职阿里巴巴。

文章中关于entity的描述参考了汤老师的下文

http://www.cnblogs.com/netfocus/archive/2011/10/10/2204949.html

陈晴阳(Sunny Chen),2003年毕业于中南大学铁道校区。高级程序员,系统分析员,微软MVP(Visual C#)。cnblogs网名daxnet,并打算以该名闯荡IT江湖。MicrosoftDynamics AX、Microsoft .NET/C#以及领域驱动设计(DDD)的狂热爱好者。

文中关于Domain Events的描述引用自

http://www.cnblogs.com/daxnet/archive/2012/12/27/2836372.html

ps:集团内阿白对于界限上下文(Bounded context)、语境映射(Context Mapping)以及域语言(Ubiquitous  Language)均有非常精彩的论述。本文作为外网公开使用,去除了相关引用,特此说明。

ps:现居于成都的老司机张逸大师对于领域建模也颇有卓见,此前有些公众号文章讨论。




相关文章
|
11月前
|
机器学习/深度学习 人工智能 量子技术
量子计算的商业化前景:未来科技的颠覆性力量
量子计算的商业化前景:未来科技的颠覆性力量
594 17
|
负载均衡 Java API
Java一分钟之-Spring Cloud OpenFeign:声明式服务调用
【6月更文挑战第9天】Spring Cloud OpenFeign是声明式服务调用库,简化了微服务间调用。通过动态代理,它允许开发者用Java接口调用HTTP服务,支持服务发现、负载均衡。本文介绍了OpenFeign的基本概念,展示了如何添加依赖、开启客户端和定义服务接口。还讨论了接口调用失败、超时重试和日志配置等问题及其解决方案,并提供了自定义Feign配置的代码示例。通过学习,读者可以更好地在微服务架构中使用OpenFeign进行服务通信。
722 4
|
机器学习/深度学习 自然语言处理 PyTorch
【机器学习】探索LSTM:深度学习领域的强大时间序列处理能力
【机器学习】探索LSTM:深度学习领域的强大时间序列处理能力
|
安全 测试技术
深入理解白盒测试:方法、工具与实践
【4月更文挑战第7天】 在软件开发的质量控制过程中,白盒测试是确保代码逻辑正确性的关键步骤。不同于黑盒测试关注于功能和系统的外部行为,白盒测试深入到程序内部,检验程序结构和内部逻辑的正确性。本文将探讨白盒测试的核心技术,包括控制流测试、数据流测试以及静态分析等方法,同时介绍当前流行的白盒测试工具,并讨论如何在实际项目中有效实施白盒测试。文章的目标是为软件测试工程师提供一份综合性指南,帮助他们更好地理解和应用白盒测试技术。
|
机器学习/深度学习 算法 数据可视化
2024美赛C题保姆级分析完整思路代码数据教学
2024美赛C题保姆级分析完整思路代码数据教学
|
缓存 关系型数据库 MySQL
MySQL登录时出现Access denied for user ‘root‘@‘localhost‘ (using password: YES)无法打开的解决方法
MySQL登录时出现Access denied for user ‘root‘@‘localhost‘ (using password: YES)无法打开的解决方法
27981 0
|
Shell Perl Linux
同源注释工具GeneWise安装和使用
这是一个非常老的软件,距离他不更新至少有10多年了,但是目前还是有很多公司用他进行基因组注释,包括ENSEMBL的注释流程的几个核心部分用到的也是它。 但是他的安装也是异常的麻烦,好在Homebrew的安装说明https://github.
3301 0
|
JavaScript 前端开发 API
十分钟轻松入门 nw.js 实现桌面应用程序
十分钟轻松入门 nw.js 实现桌面应用程序
649 0
十分钟轻松入门 nw.js 实现桌面应用程序