在Master Data Services中,Hierarchy的作用主要用于:

  • 对同属性成员进行分组
  • 聚合成员用于分析和报告输出

写在开始:显示层次结构(Explicit Hierarchy)即将在新版本中不再应用了。应该是2016。如果还在用之前的版本,并且有升级计划,最好提前准备替代方案。

在实际工作中,用于权限设置是基于第一种作用的一个重要体现。例如给不同部门同事分配不同的权限,那我们就需要在公司级别建立部门整体的业务结构,然后基于Hierarchy进行权限设置。这里有一点需要注意的是:一个层次结构必须是基于同一个模型(Model)的,不可夸模型创建层次结构。

基本介绍:

一个层次结构可以创建在一个或者多个实体(Entity)上,在MDS中有两种不同类别的层次结构:

  • 显示层次结构(Explicit Hierarchy):基于同一个实体(Entity)建立起来的层次结构。可以自由组织结构关系。每个叶子节点都可以作为当前层次的技术点,不限制结构的层次,不限制层次的成员数量。

在创建显示层次结构之前,必须在实体生启用显示结构,并命名。

  • 派生层次结构(Derived Hierarchy):基于同一个模型内部,不同实体之间的层次结构。用于描述实体与其属性之间的关系。这种关系是已经存在于实体之间的,用domain引用的方式进行关联的。

显示层次结构 vs. 派生层次结构:

显示层次结构

(Explicit   Hierarchy

派生层次结构

(Derived   Hierarchy

自定义结构

基于实体间domain引用的属性关系创建

基于一个实体内部成员创建

基于同一个模型内所有实体创建

在一个实体内部,使用合并成员来对内部其他成员进行分组

用一个实体的叶节点成员去归类另一个实体内的叶节点成员

允许任意层级数量

包含一致的层级数量

 

显示层次结构(Explicit Hierarchy):

所有层级结构的成员都是在同一个实体内部的。并且这里有两种类型的显示层次结构:

  • 强制显示层次结构(Mandatory Explicit Hierarchy)

所有的子节点成员都必须包含在层次结构中。默认的情况下是,所有成员都在根节点下。可以自己再重新组织结构。

  • 非强制显示层次结构(Non-Mandatory Explicit Hierarchy)

在此,就不过多介绍显示层次结构了,下面详细介绍派生层次结构。

派生层次结构(Derived Hierarchy):

首先需要介绍域引用(Domain-based),在创建实体的属性时,有三种类型可选:free-form, Domain-based, File。

  • Free-form:由于四种类型可以定义:文本,数字,日期时间,地址链接。都是属于基本的类型,根据实际情况选择。

如果选择Link方式,属性值必须以http:// 或者https://开头,否则的话,就会报错

例如,输入docs.microsoft.com/en-us/,然后发布;

系统在InputStatus这一列提示属性数据类型不正确。(光标放在相应的单元格上,就能看到错误提示的详细信息)

再把属性添加上https://之后,再次发布,成功提交。

  • Domain-based:引用模型内,其他实体的Code值。来达到主数据统一的目的;同时也能防止用户在录入的时候出现误差,可以通过这种方式进行规范化输入和验证。

例如在Subcategory实体中,建立Category属性,引用的是Category实体中的Code属性。

派生层次结构就是基于domain-based的属性创建的。例如我们闯将了Category,Subcategory,Product三个实体如下:

  • Category

  

  • Subcategory

其中Category属性,引用的是Category实体的Code属性,也是Category的主键。

  

  • Product

其中Subcategory属性,引用的是Subcategory实体的Code属性,也是Subcategory的主键。

  

派生层次结构(Derived Hierarchy)创建和示例:

1. MDS主页面,打开系统管理System Administration

  

2. 管理 - > 派生层次结构Derived Hierarchy
  

3. 点击 来创建一个新的派生层次结构。

  

命名成HRC_Product,然后保存。

4. 在编辑界面,需要先从最底层节点开始,也就是最细粒度的层次开始。

  

我们需要在可用层级(Available levels)下依次把Product, Subcategory, Category实体点住,然后依次拖动到Current levels: HRC_Product上。MDS的操作这里确实有个坑,开始的时候尝试了很多方法,原来直接拖动就可以的。

  

系统只支持Code属性的派生层次结构创建。

  

  

  

派生层次结构(Derived Hierarchy)修改和删除

1. 同样也是需要先打开派生层次结构界面

  

2. 点击需要修改的HRC_Product。

按钮的右边,就出现了编辑按钮和删除按钮

如果需要删除的话,直接点击删除就可以。

如果需要编辑的话,点击编辑按钮。

  

3. 编辑页面与创建是同一个。可以重命名层级名字和设置层级是否显示。

  

例如设置Subcategory不显示,效果如图;只是不显示而已,在聚合的时候,还是会按照创建的层次结构进行聚合的。

这里有两点需要注意:

第一点是最顶层和最底层的结构是必须显示的,也就是Category和Product是不允许隐藏的。

第二点是如果需要删除某一层级,必须先从最顶层的层级开始删除,不支持直接删除子层级。例如Subcateogy和Product是不允许直接删除的。

MS MDS系列之MDS层次结构(Hierarchy)的更多相关文章

  1. MS MDS系列之初始MS Master Data Service(微软主数据服务)

    背景介绍: 主数据服务(Master Data Services)是微软平台支持的主数据管理(MDM)平台.类似MDS这样的系统,如果后续维护得当,会给企业提供一个强大的中心数据库系统,来防止企业数据 ...

  2. 多MDS变成单MDS的方法

    前言 之前有个cepher的环境上是双活MDS的,需要变成MDS,目前最新版本是支持这个操作的 方法 设置最大mds 多活的mds的max_mds会超过1,这里需要先将max_mds设置为1 ceph ...

  3. ms sqlserver 系列之如何查看数据链接数

    [转]如何查看SQL SERVER数据库当前连接数 1.通过管理工具开始->管理工具->性能(或者是运行里面输入mmc)然后通过添加计数器添加 SQL 的常用统计然后在下面列出的项目里面选 ...

  4. Machine Learning for hackers读书笔记(九)MDS:可视化地研究参议员相似性

    library('foreign') library('ggplot2') data.dir <- file.path('G:\\dataguru\\ML_for_Hackers\\ML_for ...

  5. hadoop-n.x.y-src.tar.gz 、hadoop-n.x.y-src.tar.gz.asc 、hadoop-n.x.y-src.tar.gz.md5 、hadoop-n.x.y-src.tar.gz.mds是什么?

    不多说,直接上干货! 我这里,以hadoop-2.6.0为例. hadoop-n.x.y.tar.gz.mds,此mds文件是为了检验在下载和移动文件过程中文件的完整性. 通过验证文件的md5值去检验 ...

  6. hadoop-n.x.y.tar.gz、hadoop-n.x.y.tar.gz.asc 、hadoop-n.x.y.tar.gz.md5 、hadoop-n.x.y.tar.gz.mds分别是什么?

    不多说,直接上干货! 我这里,以hadoop-2.6.0为例. hadoop-n.x.y.tar.gz.mds,此mds文件是为了检验在下载和移动文件过程中文件的完整性. 通过验证文件的md5值去检验 ...

  7. MDS 多活配置

    CephFS 介绍及使用经验分享 阅读 1179 收藏 2 2019-01-14 原文链接:www.jianshu.com WebRTC SFU中发送数据包的丢失反馈juejin.im 目录 Ceph ...

  8. 吴裕雄 python 机器学习——多维缩放降维MDS模型

    # -*- coding: utf-8 -*- import numpy as np import matplotlib.pyplot as plt from sklearn import datas ...

  9. 分布式存储系统之Ceph集群MDS扩展

    前文我们了解了cephfs使用相关话题,回顾请参考https://www.cnblogs.com/qiuhom-1874/p/16758866.html:今天我们来聊一聊MDS组件扩展相关话题: 我们 ...

随机推荐

  1. 构建工具Gulp

    前面的话 与grunt类似,gulp也是构建工具,但相比于grunt的频繁IO操作,gulp的流操作能更快更便捷地完成构建工作.gulp借鉴了Unix操作系统的管道(pipe)思想,前一级的输出,直接 ...

  2. [Lucene]-Lucene基本概述以及简单实例

    一.Lucene基本介绍: 基本信息:Lucene 是 Apache 软件基金会的一个开放源代码的全文检索引擎工具包,是一个全文检索引擎的架构,提供了完整的查询引擎和索引引擎,部分文本分析引擎.Luc ...

  3. JavaScript严格模式有什么不同

    看ES6,瞄到“严格模式”,问了下自己什么是“严格模式”?答案好像不是很明朗,遂总结如下: 严格模式声明:“use strict”; 1.禁止变量未声明就赋值 2.限制动态绑定(属性和方法归属哪个对象 ...

  4. 编译MapWinGis

    其实在github下载的MapWinGIS代码,在support文件夹下的build文件夹下的HowToBuild说明已经写的很清楚了, * How to build MapWinGIS.ocx** ...

  5. Nginx+Keepalived 主备高可用 安装与配置

    环境说明:操作系统:CentOS6.7 x86_64Nginx版本:nginx-1.9.7Keepalived版本:keepalived-1.2.24 主nginx + Keepalived :10. ...

  6. linux 下用renameTo方法修改java web项目中文件夹名称问题

    经测试,在Linux环境中安装tomcat,然后启动其中的项目,在项目中使用java.io.File.renameTo(File dest)方法可行. 之前在本地运行代码可以修改,然后传到Linux服 ...

  7. JS获取浏览器类型和版本号

    JS获取浏览器类型和版本号,增加了IE11的判断. 2015/7/5更新: 简化代码逻辑 var zbrowser = {} var ua = navigator.userAgent.toLowerC ...

  8. R语言重要数据集分析研究——需要整理分析阐明理念

    1.R语言重要数据集分析研究需要整理分析阐明理念? 上一节讲了R语言作图,本节来讲讲当你拿到一个数据集的时候如何下手分析,数据分析的第一步,探索性数据分析. 统计量,即统计学里面关注的数据集的几个指标 ...

  9. [USACO09MAR]地震损失2Earthquake Damage 2

    地震破坏 时间限制: 1 Sec  内存限制: 128 MB 题目描述 威斯康星发生了一场地震!约翰的牧场遭到了打击,有一些牛棚变成了废墟,如果一间牛棚遭到 了破坏,那么所有和它相连的道路都不能使用了 ...

  10. 警惕System.Environment.CurrentDirectory 获取当前目录

    最近工作中,要做个客户端提醒的小工具:winform程序自然少不了要读取和应用程序同一个目录的配置文件(不是exe.config文件): 要读取当前应用程序所在目录我立马想到了System.Envir ...