Oracle Essbase入门系列(一)
1. 开篇序
本文是几年前做Hyperion Planning项目时写的,后来陆陆续续有些补充。本来打算将整个EPM写一系列的教程,但HFM写到1/3就没动力了。不过至少Essbase这部分是完整的。
Essbase主要是作为Planning后端数据库使用。Planning的技术难点在于Essbase,所以搞Planning深入下去就是在搞Essbase;反过来说,熟悉了Essbase,上手Planning就很简单,无非是在Essbase基础上加了Form、Process Management等功能,再学学Driver-based Planning、Rolling Forcasting等知识,就算是Planning专家了。
2. OLAP概念
联机分析处理OLAP通常是以多维的形式对数据进行钻取、汇总、切片、旋转等操作,以满足多层次、多角度数据分析的过程。OLAP包括两部分——提供用户多维操作的前端和支持多维分析的后端数据库。多维数据库,既可以是将数据以星形结构组织的RDBMS,也可以是Essbase这种专门的多维数据库。
Essbase的维度是value-based dimension,即树型结构,维度中的成员按照层次组织,形成父子级关系,其中的每个成员可包含若干个子成员。最底层的成员没有子成员,称作叶成员(Leaf Member)或基成员(Base Member),而最顶级成员是根成员。如下图的帐户维,将家庭收支项按层级关联起来形成树型结构。

维度的层级结构决定了数据沿向上合并(consolidation)和向下分配(allocation)的计算路径,如下图。

上面是单个维度的结构后,然后再来谈论多维的情况。多维数据库,顾名思义是由多个维度组成,各维度成员的组合是数据存储的最小单位,称为单元格(cell)。作为例子,假定一个家庭记账的多维数据库,由如下三个维度组成。为了便于说明,这里的维度仅截取了部分成员。
- 日期维,成员包括一季度、一月、二月、三月,其中一季度是父成员。
- 支出帐户维,成员包括日用品、衣物、洗涤,其中日用品是父成员。
- 家庭成员维,成员包括家庭、张大明、王翠花,其中家庭是父成员。
在这个多维数据库中,日期维有4个成员,支出帐户维有3个成员,家庭成员维有3个成员。那么一共有4 × 3 × 3 = 36中维度成员组合,即有36个单元格,意味着这个数据库仅能存储36个数值。将这个数据库形象的描绘成下图的三维立方体,三个维度是立方体的轴。图中以维度成员将立方体进行分割,形成了36个小块,这些小块就是单元格。如暗色单元格,是由成员组合(一月,日用品,张大明)构成。

在三个维度中,日期维的叶成员有3个,支出维的叶成员有2个,家庭成员维的叶成员有2个。则36个单元格中,有3 × 2 × 2 = 12个是叶成员组合单元格。类似单一维度成员合并方法,非叶单元格可沿维度层次,由叶单元格合并而得。例如维度成员组合(一月,日用品,张大明),由(一月,衣物,张大明)和(一月,洗涤,张大明)两个单元格汇总。

3. Essbase概念
EPM系统按产品可创建不同类型的应用程序,Essbase的应用程序是多维数据库的集合,即每个应用程序下可包含若干个多维数据库,每个数据库有独立的维度模型和数据存储。
Essbase将数据库的维度模型称为大纲(Outline),多维数据库的开发工作很大部分是大纲开发,大纲开发主要是创建维度成员和定义计算方法。
Essbase中以“代(Generation)”和“级(Level)”来标注维度层次,根成员被标注为1代,其下一层被标注为2代,依次向下代数逐渐增大;反过来,叶成员被标注为0级,其上一层被标注为1级,依次向上级数逐渐增大。以下图的维度层次为例,成员名称前的G表示代数,L表示级数。

维度的成员之间存在子代(Children)、后代(Descendants)、同级(Siblings)、父级(Parent)、祖级(Ancestors)共5种关系,说明如下。

系统架构上,Essbase是由多个组件组成。下图将Essbase的组件分成三部分,左边是Essbase Server,它是多维数据库服务,Essbase应用程序会部署到Essbase Server;右边是客户端工具,含OLAP前端应用工具和Essbase开发管理工具;在Essbase Server和客户端工具之间的是中间层服务,负责双方之间的通讯。

此外跟Essbase相关的工具主要有:
- Hyperion Planning — Planning使用Essbase作为数据库存储和计算数据。
- Hyperion Profitability and Cost Management — 跟Planning类似,HPCM使用Essbase BSO做分摊计算,使用Essbase ASO做报告。
- Essbase Analytics Link for Hyperion Financial Management — 可以将HFM数据导到Essbase中做分析。
- Hyperion Smart View — Oracle BI和EPM的客户端,跟Office整合,能直接连接Essbase数据库。
- Hyperion Visual Explorer — Tableau的OEM版本,在以前版本中会随Smart View一起安装,同样支持Essbase数据源。
- Oracle Crystal Ball — 蒙特卡罗模拟工具,新版本跟EPM整合,可以使用Essbase内部的计算代替Excel上的计算公式做模拟。
- Oracle BIEE — Oracle的BI产品,可使用Essbase作为数据源。
- Hyperion Essbase Spreadsheet Add-in — Office插件,已被Smart View取代。
Oracle Essbase入门系列(一)的更多相关文章
- Oracle Essbase入门系列(二)
本篇开始会一个三口之家的家庭财务数据库为例,讲述Essbase的功能和开发.为了说明EPM应用程序的管理和开发过程,会绕一些弯路,不使用EAS,而尽量用EPMA. 创建应用程序 首先登陆到Worksp ...
- Oracle Essbase入门系列(四)
成员存储类型 除了大纲计算,维度成员的另一项重要属性是存储类型,存储类型决定维度成员相关单元格的物理存储方式.在维库中编辑成员的[Data Storage]属性,下拉菜单中可选的5种,再加上Share ...
- Oracle Essbase入门系列(三)
数据库计算 Essbase中单元格的数据可以是外部输入或计算而得,单元格因而分为输入单元格和计算单元格.计算单元格的计算方法可以通过大纲中维度成员的合并计算符和公式脚本定义,此称为大纲计算定义. 例1 ...
- 6. oracle学习入门系列之六 模式
oracle学习入门系列之六 模式 上篇咱们学习记录了ORACLE数据库中的数据库结构.内存结构和进程等.篇幅 蛤蟆感觉偏多了.这次要休整下,每次笔记不宜太多,不然与书籍有何差别. 我们要保证的是每次 ...
- [转]oracle学习入门系列之五内存结构、数据库结构、进程
原文地址:http://www.2cto.com/database/201505/399285.html 1 Oracle数据库结构 关于这个话题,网上一搜绝对一大把,更别提书籍上出现的了,还有很多大 ...
- Jenkins入门系列之——02第二章 Jenkins安装与配置
2014-12-08:已不再担任SCM和CI的职位,Jenkins的文章如无必要不会再维护. 写的我想吐血,累死了. 网页看着不爽的,自己去下载PDF.有问题请留言! Jenkins入门系列之——03 ...
- 7.oracle学习门户系列七---网络管理和配置
oracle学习门户系列七 网络管理和配置 们学习了模式和用户.包含模式定义以及模式的作用. 这篇我么来看下ORACLE数据库中的网络管理和配置.只是这篇好像和上篇没有继承啊.这怎么看? Ok,事实上 ...
- 【JAVA零基础入门系列】Day1 开发环境搭建
[JAVA零基础入门系列](已完结)导航目录 Day1 开发环境搭建 Day2 Java集成开发环境IDEA Day3 Java基本数据类型 Day4 变量与常量 Day5 Java中的运算符 Day ...
- ABP入门系列(21)——切换MySQL数据库
ABP入门系列目录--学习Abp框架之实操演练 源码路径:Github-LearningMpaAbp 1. 引言 Abp支持MySql已经不是什么新鲜事了,但按照官方文档:Entity Framewo ...
随机推荐
- error C2275: “XXX”: 将此类型用作表达式非法
在移植c++代码到c的时候,经常会出现一个奇怪的错误,error C2275: “XXX”: 将此类型用作表达式非法 表达式非法,这个错误是由于c的编译器要求将变量的申明放在一个函数块的头部,而c++ ...
- Myeclipse/eclipse的Web project改写成Maven项目
1.导入或建立web项目时加上maven的设置 2.加入如下代码:<dependencies>标签下加入红色部分 <dependencies> <dependency&g ...
- 斯坦福第六课:逻辑回归(Logistic Regression)
6.1 分类问题 6.2 假说表示 6.3 判定边界 6.4 代价函数 6.5 简化的成本函数和梯度下降 6.6 高级优化 6.7 多类分类:一个对所有 6.1 分类问题 在分类问题中 ...
- Java中获取路径的各种方法
1. java文件中获得路径 Thread.currentThread().getContextClassLoader().getResource("") //获得资源文件(.cl ...
- Linux Kernel 3.11 正式版发布
Linus 发布 了 3.11 版本的 Linux 内核.该版本值得关注的新特性有: Lustre 分布式文件系统.透明的 ARM 架构的大数据页支持:ARM64 上的 Xen 和 KVM 虚拟化:O ...
- Dynamic CRM 2013学习笔记(三十四)自定义审批流5 - 自动邮件通知
审批过程中,经常要求自动发邮件:审批中要通知下一个审批人进行审批:审批完通知申请人已审批完:被拒绝后,要通知已批准的人和申请人.下面详细介绍如何实现一个自动发邮件的插件: 1. 根据审批状态来确定 ...
- 自己动手写客户端UI库——事件机制(设计思路大放送)
在上一篇文章中我们创建了一个Button控件,并把这个控件显示在界面上, 在这一篇文章中,我们将为这个控件增加一个事件和一个方法 一:怎么绑定事件的问题 在Winform中,我们对一个按钮绑定事件的方 ...
- SharePoint 2013 REST 以及 OData 基础
这篇文章会介绍: 简单的介绍REST,OData OData实现细节 OData在SharePoint 2013中的实现 为什么REST很重要 过去几年基于REST的webservice在IT企业越来 ...
- Minifying Angular应用时产生的问题
一.产生的问题 如果你正在进行AngularJS的项目开发,生产时Minified JS文件有没有遇到下面问题: angular.module("myApp", []) .cont ...
- 挑灯熬夜看《Build 2015 Keynote》图文笔记
又是一年微软Build大会时间,网络上流传各种微软新品发布的消息终于也要揭晓了,一直熬夜到凌晨3点,好久没有这么兴奋了. 微软给力的很嘛! Satya nadella开始讲解 首先回顾微软的传统和技术 ...