搜档网
当前位置:搜档网 › 主数据管理详解(MDM)

主数据管理详解(MDM)

主数据管理详解(MDM)
主数据管理详解(MDM)

主数据管理详解

主数据是指在整个企业范围内各个系统

(操作 /事务型应用系统以及分析型系统 )间要共享的

数据, 比如,可以是与客户 (customers),供应商(suppliers),帐户(accounts)以及组织单位(or

ganizational units) 相关的数据。主数据通常需要在整个企业范围内保持一致性 完整性 (complete) 、可控性 (controlled) ,为了达成这一目标, 就需要进行主数据管理 (Master

Data Management ,MDM) 。

什么是主数据管理 (Master Data Management , MDM)

主数据是指在整个企业范围内各个系统

(操作 /事务型应用系统以及分析型系统 )间要共

享的数据, 比如,可以是与客户(customers),供应商(suppliers),帐户(accounts)以及组织单 位 (organizational units) 相关的数据。主数据通常需要在整个企业范围内保持一致性

nt) 、完整性 (complete) 、可控性 (controlled) ,为了达成这一目标,就需要进行主数据管理 (M aster Data Management , MDM) 。需要注意的是,主数据不是企业内所有的业务数据,只

(consistent) 、

(consiste

是有必要在各个系统间共享的数据才是主数据,比如大部分的交易数据、帐单数据等都不是

主数据,而像描述核心业务实体的数据,而像客户、供应商、帐户、组织单位、员工、合作

伙伴、位置信息等都是主数据。主数据是企业内能够跨业务重复使用的高价值的数据。这些

主数据在进行主数据管理之前经常存在于多个异构或同构的系统中。

主数据管理(Master Data Management ,MDM) 是指一组约束和方法用来保证一个企业

内主题域和系统内相关数据和跨主题域和系统的相关数据的实时性、含义和质量。这是从深

层次来说来说明主动主数据管理(MDM) 的深度和复杂性,简单的说,主数据管理(MDM) 保证

你的系统协调和重用通用、正确的业务数据(主数据)。通常,我们会把主数据管理作为应用

流程的补充,通过从各个操作/ 事务型应用以及分析型应用中分离出主要的信息,使其成为

一个集中的、独立于企业中各种其他应用核心资源,从而使得企业的核心信息得以重用并确

保各个操作/ 事务型应用以及分析型应用间的核心数据的一致性。通过主数据管理,改变企

业数据利用的现状,从而更好地为企业信息集成做好铺垫。

主数据管理(MDM) 可以帮助我们创建并维护整个企业内主数据的单一视图(Si ngle View),保证单一视图的准确性、一致性以及完整性,从而提供数据质量,统一商业实体的定义,简化

改进商业流程并提供业务的响应速度。从变化的频率来看,主数据和日常交易数据不一样,变化相对缓慢,另外,主数据由于跨各个系统,所以对数据的一致性、要求很高。

实时性以及版本控制

主数据管理其实在很早之前就一直存在,只不过现在随着业务发展以及监管的需要,对主数据的实时性、准确性、一致性有了更高的要求,才被业界广泛接受,各个厂商相应的推出了一系列的主数据管理集成与基础套件以及特定领域的解决方案。近年来最明显的变化

是,客户在以前的时候经常问的问题是:主数据管理是什么”,而现在客户经常问的问题演

变成了:“我们的业务的确存在一些问题,主数据管理正好可以解决这个问题,我们怎么开

始”。与以前相比,客户对主数据管理(MDM)的认识有了巨大的进步,并开始尝试用主数据

管理(MDM)解决他们在整个企业范围内进行跨业务、跨主题域时遇上的各种挑战和问题:比如税务行业,税务局在按纳税人在一些分析统计时,就发现关于纳税人的基本信息分布在核

心征收管理系统、发票管理系统、个人所得税系统、增值税管理系统等多达几十个系统中,

使得统计分析变得困难起来,在比如在医疗设备公司,由于没有按照供应商进行产品层次的

分类,各个产品的描述也很不一样,使得产品目录的维护十分困难。随着业务的发展,对各行各业来说,生成并维护一个统一的主数据系统变的十分迫切和必要,特别是对一些跨国公

司,如何在不同的地区(各个国家和地区)的业务系统之间维护关于客户、产品目录、供应商

等信息的单一视图更是重要。

需要注意的是,主数据(Master Data)和元数据(Meta Data)是两个完全不同的概念。元数据

是指表示数据的相关信息,比如数据定义等,而主数据是指实例数据,比如产品目录信息等。

比如,某省地税开发了一套征收管理软件,以市为单位部署了17 套,每套征收管理软件中

的元数据都是一样的,但是主数据还是需要进行管理的。主数据管理和传统数据仓库解决方

案不是一个概念,数据仓库会将各个业务系统的数据集中在一起在进行业务的分析,而主数据管理系统不会把所有数据都管理起来,只是把需要在各个系统间共享的主数据进行采集和

发布。相对于传统数据仓库解决方案的单向集成,主数据管理正注重将主数据的变化同步发

布到各个关联的业务系统中(主数据管理数据是双向的)。

主数据管理问题存在的根源

对于大多数的企业都存在主数据管理的问题,个人以为这是由于业务发展的渐进性以及

IT 技术发展的渐进性造成的,正是由于这种渐进性,各大企业的业务系统从经历了从无到有,

从简单到复杂,从而形成了一个又一个的业务竖井。从根本上来说,不可能只使用一个业务

系统就能覆盖企业的所有业务,即便对一些国际大型的公司提供的套件来说也是一个不可能

完成的任务(即便对套件来说,经常也存在一个跨国企业在不同的国家或地区部署多个实例

的现象,也就是没有集中部署该套件,而是在很多地方分散部署了该套件)。对企业来说,

业务系统的构建更多是以项目为中心,从下而上的构建系统,而不是至上而下的构建系统,

必然缺乏整个企业范围内的统一规划,从而使得一些需要在各个业务中共享的数据(主数据) 被分散到了各个业务系统进行分别管理。分散管理的主数据由于没有不具备一致性、准确性、

完整性,使得各个企业普遍存在着产品管理不力、供应商管理不力、订单管理不力等现象。

解决这一问题的根本方法就是引入主数据管理(MDM) ,主数据不光指需要共享的数据,更包

含需要共享的业务规则和策略。

主数据管理(MDM) 的成熟度

根据主数据管理实施的复杂程度,参照Jill Dyche, Evan Levy 的观点大体可以把主数据

管理可以分为五个层次,从低到高反映了主数据管理(MDM) 的不同成熟度。下面我们简单介

绍一下这五个层次:

Level 0 :没有实施任何主数据管理(MDM)

在Level 0 的情况下,意味着企业的各个应用之间没有任何的数据共享,整个企业没有

数据定义元素存在。比如,一个公司销售很多产品,对这些产品的生产和销售由多个独立的

系统来处理,各个系统独立处理产品数据并拥有自己独立的产品列表,各个系统之间不共享

产品数据。在Level 0, 每个独立的应用负责管理和维护自己的关键数据(比如产品列表、客

户信息等),各个系统间不共享这些信息,这些数据是不连通的。

Level 1 :提供列表

不管公司大还是小,列表管理是我们常用的一种方式。在公司内部,会通过手工的方式

维护一个逻辑或物理的列表。当各个异构的系统和用户需要某些数据的时候,就可以索取该

用来更新或刷新需要的数据。当CRUD处理规则定义完成后,MDM Level 2需要客户或同

列表了。对于这个列表的维护,包括数据添加、删除、更新以及冲突处理,都是由各个部门

的一致性, 当业务规则发生改变或者出现类似的情况时, 这样高度手工管理的流程容易发生 错误。由于列表管理是通过手工管理的,其列表维护的质量取决于谁参加了变更管理流程, 一旦某人缺席,将会影响列表的维护。

MDM Level 1 比 MDM Level 0 的不同就是, 各个部门虽然还是独立维护各自的关键数 据,但会通过列表

管理维护一个松散的主数据列表, 能够向其他各个部门提供其需要的数据。

在 MDM Level 1 中,数据变更决定以及数据变更操作都是由人来决定的,因此,只有人完 成数据变更决定后才会变更数据。 在实际情况中, 虽然数据变更流程有严格的规定, 但是由 于缺乏集中的、 基于规则的数据管理,当数据量比较大时,数据维护的成本会变的很高,效

率也会很低。当主数据, 比如客户信息、 产品目录信息等数量比较少时,列表管理的方式是 可行的, 但是当产品目录或客户列表出现爆炸式增长以后, 起来。 MDM Level 1 依赖于人的协作。如果产品经理需要更新过后的产品价格列表,那需 要联系ERP 系统所有者,让其发送邮件给她。在企业范围内实现客户或产品列表就如同维 护不同部门之间人们的关系一样。 如果客户或产品存在层次或分组, 列表将很难提供, 并且 通常在 Level 1 因为过于复杂难以被管理。

Level 2 :同等访问 (通过接口的方式,各个系统与主数据主机之间直接互联

MDM Level 2 与 MDM Level 1 相比,引入了对主数据的 (自动 )管理。通过建立数据标

准,定义对存储在中央知识库 (Central Repository)中详细数据的访问和共享,为各个系统间

共享使用数据提供了严密的支持。

中央知识库(Central Repository)通常会被称为 主数据主机

(Master Data Host) 。”这个知识库可以是一个数据库或者一个应用系统,通过在线的方式支 持数据的访问和

共享。

创建、读取、更新和删除 (CRUD)是处理基本功能的典型编程术语。即便在 MDM 中,C

RUD 处理也是基本功能。你的数据库如果仅仅支持 CRUD 处理并不意味着你实现了 MDM Level 2引入了 同等访问”(peebased access),也就是说一个应用可以调用另一个应

的工作人员通过一系列的讨论和会议进行处理的。

业务规则(Business Rules)是用来反映价值

列表管理的变更流程将变得困难

MDM 。

用来更新或刷新需要的数据。当

CRUD 处理规则定义完成后, MDM Level 2需要客户或 同

等”应用格式化请求 (和数据 ),以便和 MDM 知识库保持一致。 MDM 知识库提供集中的数据 存储和供应

(provisioning ) 。在这个阶段,规则管理、数据质量和变更管理必须在企业范围内 作为附加功能定制构建。

比如,一个数据库或一个打包应用 (比如一个销售自动化系统 )对外部应用提供数据访问 功能。当一个外部应用 (比如呼叫中心应用 )需要增加一个客户,这个外部应用将提交一个事 务,请求数据所有者增加一个客户条目。主数据主机

(Master Data Host )将增加数据并告知

外部应用。CRUD 处理方式比纸上办公有了很大提高,其是基于会话的数据管理。在

Level 1,数据变更是基于手工的方式。在

MDM Level 2, 数据变更是自动完成的 —通过由

使用和变更单一、共享的数据知识库。 MDM Level 2 需要每个同等应用理解基本的业务规 则以便访问主列表、与主列表进行交互。因此,每个同等应用必须正确恰当地创建、增加、 更新和删除数据。授权应用有责任坚持数据管理原则和约束。

Level 3 :集中总线处理

与 MDM Level 2 相比, MDM Level 3 打破了各个独立应用的组织边界,使用各个系统

都能接受的数据标准统一建立和维护主数据 (MDM Level 2 的主数据主机上存储的数据还是

用集中管理方式。 这意味着应用系统, 作为消费者或使用主数据, 拥有一个共识就是数据是

MDM

具体技术实现的标准流程,允许多应用系统修改数据。

MDM Level 2 可以支持不同的应用

按照各个系统分开存储的,没有真正的整合在一起

)。

集中处理意味着为 MDM 构建了一个通用的、 基于目标构建的平台。 大多数公司发现

DM 正在挑战他们现有的IT 架构:他们拥有太多的独立平台处理主数据。

MDM Level 3

中数据访问、 控制跨不同应用和系统使用数据。 这极大的降低了应用数据访问的复杂性, 大简化了面向数据规则的管理, 使 MDM 比一个分散环境具有更多的功能和特点。 企业主数 据面临一致性的挑战。 数据在不同的地方存在, 数据所代表的含义也是不同的, 数据的规则

各个系统之间也是不一样的。 集中 MDM 处理-通过一个公共的平台作为一个总线

(HUB)-说明

一个共识, 从多个系统整合主题域数据, 意味着使用集中、 标准化的方法转换异构操作数据, 不管其在源系统中是什么样子,都会被整合起来。在

MDM Level 3,公司对主题域内容采

主题数据内容的映像,打破了各个独立应用的组织边界。MDM Level 3 支持分布主参考数

据的存在。

MDM 的核心之一就是保证所有系统都能接受数据表示的唯一公认方法。这有点类似

于语言翻译,通过其他语言的翻译,英语已经称为一个全球性的语言。在MDM Level 3,

一个公司可以让任意两个系统共享数据和说对方的语言。MDM Level 3 还降低了等同访问

的复杂性。"消费"应用不再需要支持系统定位和操作逻辑。任何与源系统数据相关的分布式

细节都会被MDM 总线集中处理。在MDM Level 3 自动数据标准意味着:建立目标数据值

表示和通过必要的步骤提供精确的主数据值捕获。在所有的分类中从MDM Level 3 开始第

一次支持一致性的企业数据视图。数据质量规则在这里进行数据清洗和错误纠正。

Level 4 :业务规则和政策支持

一旦数据从多个数据源整合在一起,主题域视图超越单独的应用并表现为一个企业视

图,你将获得事实的单一版本。当事实的单一版本已经能够提供出来时,来自业务主管和执

行人员的必然反应经常是:“证明它”。MDM Level 4可以保证主数据反映一个公司业务规

则和流程,并证实其正确性。MDM Level 4 通过引入主数据来支持规则,并对MDM 总线

以及其它外部系统进行完整性检查。由于多数公司相对比较复杂,影响业务数据访问和操作

的规则以及策略(rules and policies)相对也比较复杂。假定任何一个单一系统可以包含并管

理与主参考数据相关的各种类型的规则是不切实际的。因此,如果一个MDM 总线真正打算

提供企业范围内数据的精确性,工作流和流程整合的支持是必不可少的。

举例来说,在一个HMO 内,需要多个应用来支持一个病人的护理。一个单一的访问(v

i sit)可能包括入院、房间和床位分配、监控设备、化验、身体检查以及其他程序等。一旦一

个病人准备离开医院,出院流程需要确保和这个病人相关的所有活动、资源都被结清。MD M 技术在召集多个应用系统一起保证病人辨识方面是十分有效的,处理是正确的。虽然病

人辨识很重要,业务规则整合同样重要。临床系统依靠一系列的业务流程和数据规则来辨别

所有显着的病人详细资料。这包括返回所有基于房间的资源(监护设备、床位等)以得到有用

的详细目录,当病人要出院时分解其所有的费用。

MDM 保证当John Smith 出院时,正确的

相关主题