运用四色建模法进行领域分析

领域建模有很多种方法,对于同样的问题域使用不同的建模手段得到的模型可能也不尽相同。于是我经常听到这样一个问题:怎么才能保证建模的正确性?

这听起来是个合理的质疑,但实际上却不是那么有道理。首先我们需要明白建模的目的是什么?如果仅仅是为了描画问题,那么并没有什么对错之分——仅仅是立场和角度的差别;而如果是为了企业业务系统而进行建模,那么这个问题应该变为:如何保证模型能够支撑企业的运营?

我想用下面这个例子来简要的回答一下这个问题。

在开始分析和建模之前,我们需要知道企业业务系统的目的是什么;而企业业务系统的目的往往跟决策者或者管理的诉求相关。我们现在需要移情到一位管理者身上,看看他的诉求到底是什么。

现在假想你是一家在线电子书店的 COO。突然有一天,有一位顾客向你投诉,说他订购的书少了一本,并且价钱算错了,他多给了钱。在你承诺理赔之前,你需要核对一下这位顾客说的是否属实。那么这个时候你需要知道什么样的信息才能做出准确的判断呢?

简单来说,你需要知道这位顾客订购了那些书籍,付了多少钱以及书店到底为这个顾客递送了那些书籍。不幸的是,由于科技不够发达,你无法直接驾驶时间机器回到从前去亲眼看看发生了那些事。但幸运的是,你并不需要这么做,你只需要看看这位顾客的订单,和网银的支付记录以及你们书店交给 EMS 的快递单存根,就应该知道这些信息了。

你找到了订单和 EMS 快递存根。发现这位顾客是在三天前订购的书,而你们在前天就已经将书邮寄出去了。并在订单上看到这位顾客一共订购了 7 本书,但是在 EMS 的快递存根上,并没有任何书籍的信息,只有地址,包裹号,邮费和重量什么的信息。这时候你觉得应该去询问一下配送部门,看看他们做了什么。

在配送部门你根据包裹号查到了那个包裹的信息,果然里面只有 6 本书。同时你在包裹部门发现了一张延期交货单。上面说明由于缺货,这位顾客另外一本书正在等待发货。

那么剩下的问题就是支付问题了,从网银的记录上看,客户不含邮费一共支付了 132.5。订单上显示的价钱也是 132.5,显然这位顾客并没有多付钱。

为了保证准确,你重新从网站上选了这 7 本书,想看看是否也会是这个价钱。但你却意外的发现,一共只需要 128.3。仔细辨认后,你发现有一本图书现在是促销。那么现在的问题是,促销到底是什么时候开始的?

你到了市场部,市场部给了你一份近期促销计划。你发现那本书是昨天才开始促销的,也就是说在那位顾客在下订单的时候,促销还没有开始。

这个时候,你觉得应该给你的顾客打一个电话致歉,商讨如何后续邮寄的问题,并向他说明促销的事情。

你是否觉得这个 COO 当得有点累呢?这当然是虚构的。但是从这故事里面我们看到什么呢?

任何的业务事件都会以某种数据的形式留下足迹。我们对于事件的追溯可以通过对数据的追溯来完成。正如上面这个故事里,你无法回到从前去看看到底发生了什么,但是却可以在单据的基础上,一定程度的还原当时事情发生的场景。当我们把这些数据的足迹按照时间顺序排列起来,我们几乎可以清晰的推测出这个在过往的一段时间内到底发生了那些事情。

那么为什么这些数据形成的链条能够成帮助我们追溯业务的营运呢?

因为这些数据并不是随便挑选的。如果我们回顾一下你作为 COO 检查这个疏漏的过程,你首先选择了订单和 EMS 快递存根,换句话说,如果订单出现差错,或者 EMS 快递存根上说明你的确邮寄了 7 本书,那么这个疏漏的责任并不在你。所以这两个订单实际上这个你这个企业法律责任的起点和终点。

当你确定这个疏漏的责任在你之后,你选择审查一些流程执行的结果,比如包裹存根。从而验证一些主要的业务流程执行的结果是否正确。换句话讲,这些数据是支撑你运营体系的关键流程的执行结果。

正是由于这些数据是流程执行的结果,它们才使我们可以在不了解流程细节的前提下,对某些突发事件进行追述和分析。

除了上面那个极端的例子(投诉),对于任何一笔正常的经济往来,我们都需要知道:

  1. 如果我付出一笔资金,那么我的权益是什么?

  2. 如果我收到一笔资金,那么我的义务是什么?

而这些问题都需要业务系统捕捉到相应的足迹才能够回答。所以企业的业务系统主要的目的之一,就是记录这些足迹,并将这些足迹形成一条有效的追溯链。

而作为业务分析师的你,则应该知道那些事件在运营上是需要追溯的,这些事件都留下了什么足迹。

这些足迹通常都具有一个有意思的特性,即它们都是时标性对象(moment-interval)。发现这些时标性对象就是建模的起点。对于这些时标性对象稍加整理,我们就得到了整个领域模型的骨干:

在得到骨干之后,我们需要丰富这个模型,使它可以更好的描述业务概念。这时候,我们需要补充一些实体对象。通常实体对象有三类:人,地点, 物(party/place/thing)。

在这个基础上,我们可以进一步抽象这些实体事如果参与到各种不同的流程中去的,这时候,我们就需要用到角色(role):

最后再把一些需要描述的信息放入描述对象(description)。

我们就得了应用四色建模方法(color modeling)建立的一套领域模型。

简要回顾一下上面的过程,不难发现我们建模的次序和重点:

  1. 首先以满足管理和运营的需要为前提,寻找需要追溯的事件。

  2. 根据这些需要追溯,寻找足迹以及相应的时标性对象。

  3. 寻找时标对象周围的人/事/物

  4. 从中抽象角色

  5. 把一些信息用描述对象补足。

由于在第一步中,我们就将管理和运营目标做为建模的出发点。因此,整套模型实际上是围绕这些“如何有效地追踪这些目标”而建立的,这样的模型可以保证模型支撑企业的运营。

附言

几位同事帮我审校这篇文章的时候,有人问了一个很有意思的问题:为什么你会以一个看上去像极端情况的例子来说明这个建模方法? 以我的经验来看,对于业务系统有两个东西是很重要的:可追溯性(traceability)和执行效率(efficiency)。这里的可追溯性是指责任的可追溯性(traceability of liability),而通常都是在一些不太好的事情发生之后,才需要对责任进行追溯。所以想一个相对负面的例子更容易帮助我们找到建模所需要解决的问题。

另外还有位同事说,你的四色方法与 Peter Coad 的四色法并不完全相同。是的,我所介绍的并不是 Peter Coad 的四色法, 我不敢说是发展, 仅仅是对于 Peter Coad 四色的一种变化吧。

作者:徐昊

(0)

相关推荐

  • 使用 DDD 指导微服务拆分的逻辑

    对于服务拆分的逻辑来说,是先设计高内聚低耦合的领域模型,再实现相应的分布式系统.服务的划分有一些基本的方法和原则,通过这些方法能让微服务划分更有操作性.最终在微服务落地实施时也能按图索骥,无论是对遗留 ...

  • 古籍 朝鲜抄本四柱吉法

    古籍 朝鲜抄本四柱吉法

  • 美食推荐:四色炒玉米,凉拌油麦,老油条炒丝瓜,辣子鸡翅

    辣子鸡翅 材料:鸡翅中6个,料酒适量,盐3克,淀粉适量,干辣椒3把,花椒适量,大蒜8瓣,生姜适量,白糖1勺,香醋1勺,酱油1勺 做法: 1.每个鸡翅中洗净后切成两三段,加入料酒,盐2克,腌1个小时左右 ...

  • 四年级科学期中考试试卷分析

    一.试题分析: 本次试题共有五个大题,题目难易程度适中,都是课本基础知识,适合大多数学生做. 题目类型包括:一.知识展示台,共20分,主要考查学生对课本知识点掌握的情况,既有基础知识的考查也有理解性的 ...

  • WCAA·NGA周赛#4结束 恭喜BLIND KITTY操控四色历险夺冠!

    WCAA·NGA联赛第四周周赛(比赛信息) WCAA·NGA 万智牌竞技场联赛 第四周周赛(标准)全满结束,恭喜 BLIND KITTY 操控四色历险夺冠获得200元奖金,以及亚军 Killstrik ...

  • 【攻略】标准四色欧那斯(有效期5天)

    威世智刚发了公告说要在下周一对标准赛制动刀,很显然就是针对现在的毒瘤--四色欧那斯,虽然如此,但我还是想趁最后这几天来分享一些我关于这套牌的理解.现环境中它的强度实在太高,玩起来也非常有意思,非常推荐 ...

  • WCAA·NGA周赛#2结束 恭喜我自己使用四色欧那斯夺冠!

    WCAA·NGA联赛 第二周周赛(比赛信息) WCAA·NGA 万智牌竞技场联赛 第二周周赛全满结束,恭喜 QiuLaohan 操控四色欧那斯夺冠获得200元奖金,以及亚军 KingofMTGA 获得 ...

  • 【META】PTF第一天结束 四色复归荒野或为最大赢家

    [上周META]标准环境已被彻底破解--本周三场大赛总结 本周末正在进行一场逼格等级最高的比赛--PTF,共有145名顶级高手参与瓜分$250,000总奖金池.在这个"已经被破解" ...

  • 【全套】2021“红橙黄蓝”四色风险分级管控图及告知卡编制解读

    安全风险等级从高到低划分为重大风险.较大风险.一般风险和低风险,分别用红.橙.黄.蓝四种颜色标示.▼参考图例 风险等级一定程度上取决于严重程度等级和可能性等级这里给大家一个参考 作业条件危险性分析法L ...

  • 入地眼二十四山砂法

    二十四山砂法 乾砂法 乾峰冲天秀入云,龙头独步黄金门.若见低圆正而丽,定主科甲在前列. 乱峰低小富豪翁,世登要路跨乾峰.独有乾峰陡然起,经略之士端可拟. 参军司户小峰峦,低圆方正富而已.龙真穴备造化工 ...