EA 中的业务对象和业务实体你分得清吗?

2024-02-09 01:20

本文主要是介绍EA 中的业务对象和业务实体你分得清吗?,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

我们在业务建模的时候会经常用到业务实体和业务对象这两个术语,很多人经常容易混淆。本文将试图对这两个术语混淆的原因进行分析,并给出具体操作使用建议。

业务概念

业务对象和业务实体都来自业务概念。业务概念是对业务领域中很重要的,企业希望识别的一些人、事、物。例如,“客户”、“营业员”、“对账”、“分润”、“账户”、“物流单”、“订单”、“仓库”、“合同”等。这些业务概念将被以一个或多个名称引用,也就是业务术语。

业务概念包括无生命的“事物”和有生命的“人”。有生命的人通常是业务领域中业务行为的“主动方”,如“客户”、“营业员”。无生命的“事物”通常是业务领域中的“被动方”,如“对账”、“分润”、“账户”、“物流单”、“订单”、“仓库”、“合同”。

业务概念

业务对象

对象在词典中的定义是“1)行动或思考时作为目标的人或事物;2)特指恋爱的对方‘’,我们在此谈论的当然是前者。

但由于视角-也就是目标指向-不同,在不同体系中对业务对象的含义可能并不相同。

在 Togaf ,没有对业务对象的严格定义,但在 Archimate 中,业务对象被描述为“业务观点相关的被动因素”。此处业务观点和业务概念是一个意思。

在 UML 中,对象的含义来自面向对象的方法。面向对象的方法是一种编程范式,主要是把事物给抽象化、对象化,包括其属性和行为。我们经常说“万物皆对象”,就是任何人、事、物、过程都可以通过抽象进行表达,进一步通过聚合数据和方法封装成类。面向对象是将现实世界映射为信息世界的一种方式。

在 UML 中,业务对象的分类如下:

  1. 业务边界对象:承担人机交互; 

  2. 业务控制对象:控制管理,协调任务; 

  3. 业务实体对象:一般事物(无生命);

  4. 业务工人:业务领域的人(有生命)。

在 UML 中,业务对象是业务建模的目标。业务建模的过程就是业务领域的重要的人、事、物、过程抽象为业务对象的过程。业务对象既包括了组织内部业务行为中的主动方(如业务工人),也包括被动方(如业务实体、业务控制和业务边界)。后续这些信息对象将进一步聚合值属性和行为属性,并封装为类。

在 Togaf 最新发布《The Open Group 指南:金融行业参考模型: 银行业架构网络(BIAN)的 ArchiMate® 建模符号》的指南中(以下简称金融行业参考指南)对业务对象有了更为详细的描述。

为了通知企业有关其感兴趣的概念的信息,需要捕获和管理数据。但是,业务概念并不是指导有效的数据架构所需的信息架构的构建模块。业务信息架构的构建模块是业务对象。它是一个相互独立、完全穷尽的信息单元。业务对象相互关联,从而构成业务对象模型(BOM)。业务对象是业务概念或其抽象。因此,它也需要用业务术语来命名。

《The Open Group 指南:金融行业参考模型: 银行业架构网络(BIAN)的 ArchiMate® 建模符号》

图 业务对象模型(BOM)内容模式。

在金融行业参考指南中,业务对象被用于企业信息架构(EIA)建模,而定性的企业信息架构是定性的数据架构管理的先决条件。在该指南中,业务对象侧重于对名称相同的业务概念的信息捕捉和数据描述,是信息世界的范畴,这也使之和现实世界的业务实体区分开来。

图 金融行业参考模型中的业务对象

业务实体

在 Togaf 中,没有对业务实体进行严格定义,但在 Archimate 中,我们看到业务施动者(包括业务参与者 Business Actor 和业务角色 Buisness role)称为业务实体。

而在 UML 中,业务实体的概念与 Archimate 完全不同。在 UML 中,业务参与者(Buiness Actor)是组织外部的业务主动方元素,如用户、供应商和监管机构。业务工人(Buinese Worker)是组织内部的业务主动元素,如营业员。业务实体(Buinese Entiy)则是上述业务主动元素操作和执行的目标,一般是无生命事物。

在 Togaf 中,业务实体的含义是现实世界的“人”,是业务施动者,是业务主动元素。而在 UML 中业务实体的概念是业务施动者操作和执行目标,是业务被动元素。两者的含义已经是风马牛不相及了。

表1 Togaf和UML中业务对象和业务实体的差异

总结和建议

  • 业务对象和业务实体都来自业务概念,都是业务建模的术语;

  • 由于视角和理解的不同,不同体系在业务建模过程中,业务对象和业务实体两个术语的含义可能大相径庭(如表 1),使用要考虑语境和上下文;

  • 在 Togaf 中,对业务对象的使用可参考金融行业参考模型;

  • 在 Togaf 中,尽量减少业务实体这一术语的的使用以避免歧义。

End

参考文档

1、https://www.cnblogs.com/johnnyzen/p/8035749.html

2、《The Open Group 指南:金融行业参考模型: 银行业架构网络(BIAN)的 ArchiMate® 建模符号》


非实践,不架构。EA学习帮期待你的加入!

这篇关于EA 中的业务对象和业务实体你分得清吗?的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

JavaScript对象转数组的三种方法实现

《JavaScript对象转数组的三种方法实现》本文介绍了在JavaScript中将对象转换为数组的三种实用方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友... 目录方法1:使用Object.keys()和Array.map()方法2:使用Object.entr

使用MapStruct实现Java对象映射的示例代码

《使用MapStruct实现Java对象映射的示例代码》本文主要介绍了使用MapStruct实现Java对象映射的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,... 目录一、什么是 MapStruct?二、实战演练:三步集成 MapStruct第一步:添加 Mave

Java中实现对象的拷贝案例讲解

《Java中实现对象的拷贝案例讲解》Java对象拷贝分为浅拷贝(复制值及引用地址)和深拷贝(递归复制所有引用对象),常用方法包括Object.clone()、序列化及JSON转换,需处理循环引用问题,... 目录对象的拷贝简介浅拷贝和深拷贝浅拷贝深拷贝深拷贝和循环引用总结对象的拷贝简介对象的拷贝,把一个

使用Java读取本地文件并转换为MultipartFile对象的方法

《使用Java读取本地文件并转换为MultipartFile对象的方法》在许多JavaWeb应用中,我们经常会遇到将本地文件上传至服务器或其他系统的需求,在这种场景下,MultipartFile对象非... 目录1. 基本需求2. 自定义 MultipartFile 类3. 实现代码4. 代码解析5. 自定

javaSE类和对象进阶用法举例详解

《javaSE类和对象进阶用法举例详解》JavaSE的面向对象编程是软件开发中的基石,它通过类和对象的概念,实现了代码的模块化、可复用性和灵活性,:本文主要介绍javaSE类和对象进阶用法的相关资... 目录前言一、封装1.访问限定符2.包2.1包的概念2.2导入包2.3自定义包2.4常见的包二、stati

MyBatis-Plus 自动赋值实体字段最佳实践指南

《MyBatis-Plus自动赋值实体字段最佳实践指南》MyBatis-Plus通过@TableField注解与填充策略,实现时间戳、用户信息、逻辑删除等字段的自动填充,减少手动赋值,提升开发效率与... 目录1. MyBATis-Plus 自动赋值概述1.1 适用场景1.2 自动填充的原理1.3 填充策略

Python实现对阿里云OSS对象存储的操作详解

《Python实现对阿里云OSS对象存储的操作详解》这篇文章主要为大家详细介绍了Python实现对阿里云OSS对象存储的操作相关知识,包括连接,上传,下载,列举等功能,感兴趣的小伙伴可以了解下... 目录一、直接使用代码二、详细使用1. 环境准备2. 初始化配置3. bucket配置创建4. 文件上传到os

SpringMVC高效获取JavaBean对象指南

《SpringMVC高效获取JavaBean对象指南》SpringMVC通过数据绑定自动将请求参数映射到JavaBean,支持表单、URL及JSON数据,需用@ModelAttribute、@Requ... 目录Spring MVC 获取 JavaBean 对象指南核心机制:数据绑定实现步骤1. 定义 Ja

Python打印对象所有属性和值的方法小结

《Python打印对象所有属性和值的方法小结》在Python开发过程中,调试代码时经常需要查看对象的当前状态,也就是对象的所有属性和对应的值,然而,Python并没有像PHP的print_r那样直接提... 目录python中打印对象所有属性和值的方法实现步骤1. 使用vars()和pprint()2. 使

MySQL JSON 查询中的对象与数组技巧及查询示例

《MySQLJSON查询中的对象与数组技巧及查询示例》MySQL中JSON对象和JSON数组查询的详细介绍及带有WHERE条件的查询示例,本文给大家介绍的非常详细,mysqljson查询示例相关知... 目录jsON 对象查询1. JSON_CONTAINS2. JSON_EXTRACT3. JSON_TA