【BIEE】15_时间维度建立
时间维度的建立
1.环境准备
①新建时间维度表:TIME_DIMENSION
建立时间维度表并插入数据
---------------创建时间维度表
create table TIME_DIMENSION
(
the_date NUMBER not null,
date_name NVARCHAR2(15),
the_year NUMBER,
year_name NVARCHAR2(10),
the_quarter VARCHAR2(10),
quarter_name NVARCHAR2(10),
the_month NUMBER,
month_name NVARCHAR2(10),
the_week NUMBER,
week_name NVARCHAR2(10),
week_day NVARCHAR2(10)
)
tablespace users
pctfree 10
initrans 1
maxtrans 255
storage
(
initial 64
next 1
minextents 1
maxextents unlimited
); --创建存储过程脚本:
CREATE OR REPLACE PROCEDURE SP_CREATE_TIME_DIMENSION(begin_date in varchar2,
end_date in varchar2) is /*SP_CREATE_TIME_DIMENSION: 生成时间维数据
begin_date: 起始时间
end_date:结束时间
*/
dDate date;
v_the_date number;
v_the_year varchar2(4);
v_the_quarter varchar2(2);
v_the_month varchar2(10);
v_the_month2 varchar2(2);
v_the_week varchar2(2);
v_the_day varchar2(10);
v_the_day2 varchar2(2);
v_week_day nvarchar2(10); adddays int;
BEGIN
adddays := 1 ;
dDate := to_date(begin_date,'yyyymmdd'); WHILE (dDate <= to_date(end_date,'yyyymmdd'))
loop
v_the_date := to_number(to_char(dDate,'yyyymmdd'));--key值
v_the_year:= to_char(dDate, 'yyyy');--年
v_the_quarter := to_char(dDate, 'q');--季度
v_the_month:=to_char(dDate, 'mm');--月份(字符型)
v_the_month2:=to_number(to_char(dDate, 'mm'));--月份(数字型)
v_the_day:=to_char(dDate, 'dd');--日(字符型)
v_the_day2:=to_char(dDate, 'dd');
v_the_week:= to_char(dDate,'fmww');--年的第几周
v_week_day := to_char(dDate, 'day'); --星期几 insert into time_dimension(the_date,date_name,the_year,year_name,
the_quarter,quarter_name,the_month,
month_name,the_week,week_name,week_day)
values(v_the_date,v_the_year||'年'||v_the_month2||'月'||v_the_day2||'日',v_the_year,v_the_year||'年',
v_the_year||'Q'||v_the_quarter,v_the_year||'年'||v_the_quarter||'季度',to_number(v_the_year||v_the_month),
v_the_year||'年'||v_the_month2||'月',v_the_week,'第'||v_the_week||'周',
v_week_day); dDate := dDate + adddays;
END loop;
end SP_CREATE_TIME_DIMENSION; --执行存储过程 call SP_CREATE_TIME_DIMENSION(19800101,19900101);
commit;
② 事实表直接使用EMP表即可,在该表的基础上新增一列,为后边与时间维度表关联做准备
ALTER TABLE EMP ADD S_HIREDATE NUMBER;
update emp set S_HIREDATE=to_number(to_char(hiredate,'yyyymmdd'),99999999)
2.数据导入资料库
【打开PRD】—【导入元数据】--【此处数据库为Oracle:选择OCI 10g/11g】



接着【下一步】

表导入完成后

3.建立物理层
此时,为了【①保留原先导入表的信息与结构;②给表排序(次要)】,我们为每个表建立别名
右键表名---然后【新建对象】---【别名】

同理,为维度表【TIME_DIMENSION】也建立别名,建立完成以后如下图

接着进行表关联
【选中所建立的别名:Dim_01_time与Fat_01_emp】--【右键】---【物理图表】---【仅限所选对象】


定义好的维度关系如下:

连接建立完毕后如下图:

4.模型层设计
我们可以将物理层直接拖拽到模型层,此时,我使用新建
点击【业务模型和映射】空白处-----右键---【新建业务模型】
此处,我们就保持跟物理层一致,用【SCOTT】命名

建立完成后

此时,我们将需要的拖拽到【业务模型和映射层】

通过上图,我们就可以看到带#号的便是事实表,不带的是维度表
接着,开始建立【时间层次结构】
【右键时间维度表】--【创建逻辑维】--【具有基于级别的层次维度】,创建完成后会出现一个三维坐标图标

【展开这个三维坐标图标】--【选中Detail层,右键】—【新建对象】--【父级】--【新建:月】

建立完成后如下:

我们的【Detail层相当于日,直接修改为日即可】


然后右键【月】--新建【季】,接着建立【年】

层级建立好之后,我们把每个层级对应的字段拖到对应层级下,例如:将Detail下的THE_MONTH拖到【月】下边

其他维度也一样,拖拽完毕后,删除多余的字段

从上图我们看到,【日】下的对应字段是一个黄色的小钥匙标志,这个叫做【逻辑关键字】,年、季、月也需要这种关键字
右键【月】下的【THE_MONTH】--【新建逻辑级别关键字】

点击【确定】后,我们可以看到,在【月】下边可以看到小钥匙也出现了,依次设置【季、年】

设置完毕后

此时,我们修改一下维度的中文显示(双击即可修改)

上述维度建立完成后,那么接下来就是设置事实表的聚合规则
展开【维度表】,双击【EMPNO】,此处统计客户数,选择【Count Distinct】

设置完成后,我们发现字段EMPNO变成黄色的了

同时,也可以【新建逻辑列】,例如:我们要计算每个员工的总收入(工资+奖金)
点击【Fat_01_emp】--【右键】--【新建对象】--【逻辑列】

设置列源来自【现有列派生】

点击【确定】后

同时将SAL、COMM字段的聚合规则设置为SUM
接着,模型层优化与美化:①把不需要的字段删除 ②把英文改为中文

上述时间表的【年、季、月、日】显示顺序,可以双【Dim_01_时间】进去修改

5.展现层设计
直接将模型层拖拽到表示层即可。
如果表太多,可以在表示层对事实表与维度表分类
我们在主题区域上新建表示表。【单击SCOTT】--【右键】--【新建表示表】(例如:维度)

双击【维度】

点击【绿色加号】

选择【Dim_01_时间】后

此时,再次保存资料库,登录BIEE主页

从上图,我们可以看出,时间维表已经被放在文件夹【维度】下边了
简单测试:
我们拖动字段制作分析如下

保存后,打开分析

点击季度值后可以一一展开【钻取】

【BIEE】15_时间维度建立的更多相关文章
- 《BI项目笔记》创建时间维度(2)
创建步骤: 序号 选择的属性 重命名后的名称 属性类别 1 DateKey DateKey 常规 2 Month Key Month Key 月份 3 English Month Name Eng ...
- 《BI项目笔记》创建时间维度(1)
SSAS Date 维度基本上在所有的 Cube 设计过程中都存在,很难见到没有时间维度的 OLAP 数据库.但是根据不同的项目需求, Date 维度的设计可能不大相同,所以在设计时间维度的时候需要搞 ...
- DAX/PowerBI系列 - 关于时间系列 - 如何用脚本生成时间维度 (Generate Date Dimension)
跟大家的交流是我的动力. :) DAX/PowerBI系列 - 关于时间系列 - 如何用脚本生成时间维度 (Generate Date Dimension) 难度: ★☆☆☆☆(1星) 适用范围: ★ ...
- MySQL学习笔记:生成时间维度表
# ---- 对应时间戳怎么生成的? ---- /*TIME_CD TIME_CD1000000 000005000001 000005000002 000005000003 000005000004 ...
- DAX/PowerBI系列 - 关于时间系列 - 如何用脚本生成时间维度 (Generate TIME Dimension)
DAX/PowerBI系列 - 关于时间系列 - 如何用脚本生成时间维度 (Generate TIME Dimension) 难度: ★☆☆☆☆(1星) 适用范围: ★★★★★(5星) 这个时间系列想 ...
- 揽货最短路径解决方案算法 - V2(增加了时间维度-客户允许的服务时间段,C#/JAVA同步实现,带python作图)
继上篇,这里改进增加了客户允许服务的时间范围这个维度,并且把C#版本翻译成java,加强了更加形象的图表展示路径(继续是用python的matplotlib作图). 这里的时间范围维度是指:每个客户都 ...
- 【BIEE】BIEE报表根据维度表展示事实表不存在的维度
事实表数据 维度表数据 现在报表展示如下: 这样展示报表让人感觉数据缺失了,需要显示成如下样子,感觉会比较舒服一点 那么,如何实现上面的完美操作呢? 实现步骤 分析编辑页面→表视图属性→包含仅具有空行 ...
- [Java Code] 时间维度循环生成代码片段
public static void main(String[] args) throws ParseException { String str = "20140301"; St ...
- MySQL学习笔记:生成时间维度表2
实现目的: 测试: # 测试 加一秒 SECOND), INTERVAL SECOND); SECOND),'%H%i%s');# 第一秒 SECOND),'%H%i%s');# 最后一秒 SELEC ...
随机推荐
- AC日记——【清华集训2014】奇数国 uoj 38
#38. [清华集训2014]奇数国 思路: 题目中的number与product不想冲: 即为number与product互素: 所以,求phi(product)即可: 除一个数等同于在模的意义下乘 ...
- zookeeper与activemq整合
(1)zookeeper与activemq原理 使用ZooKeeper实现的Master-Slave实现方式,是对ActiveMQ进行高可用的一种有效的解决方案,高可用的原理:使用ZooKeeper( ...
- (12)python 标准库
模块 如果模块和自己写的程序不在同一个目录,可以通过sys.path.append(路径)把程序引入 import sys sys.path.append('C:/abc')#注意 \ 的方向 意思是 ...
- 洛谷 P3927 SAC E#1 - 一道中档题 Factorial【数论//】
题目描述 SOL君很喜欢阶乘.而SOL菌很喜欢研究进制. 这一天,SOL君跟SOL菌炫技,随口算出了n的阶乘. SOL菌表示不服,立刻就要算这个数在k进制表示下末尾0的个数. 但是SOL菌太菜了于是请 ...
- NOIP2014飞扬的小鸟
长为n,高为m的二维平面,其中有k个管道(忽略管道的宽度)小鸟始终在游戏界面内移动.从最左边任意高度位置出发,到达游戏界面最右边,游戏完成每个单位时间沿横坐标方向右移距离为1,竖直移动的距离由玩家控制 ...
- 模板-网络流-Dinic
//Dinic struct Edge{ int from,to,cap,flow; Edge(){ } Edge(int a,int b,int c,int d){ from=a; to=b; ca ...
- 线段树+Dfs序【p2982】[USACO10FEB]慢下来Slowing down
Description 每天Farmer John的N头奶牛(1 <= N <= 100000,编号1-N)从粮仓走向他的自己的牧场.牧场构成了一棵树,粮仓在1号牧场.恰好有N-1条道路直 ...
- (转载)UIKIt力学教程
转载自:http://www.cocoachina.com/ios/20131226/7614.html 这篇文章还可以在这里找到 英语, Ray:这篇教程节选自 iOS 7 教程集,它是 iOS ...
- 【计算几何】【二分答案】【最大流】bzoj1822 [JSOI2010]Frozen Nova 冷冻波
用三角形面积什么的算算点到直线的距离之类……其实相切的情况是可行的……剩下的就跟某SDOI2015一样了. #include<cstdio> #include<cmath> # ...
- 【二分答案】【分块答案】【字符串哈希】【set】bzoj2946 [Poi2000]公共串
我们二分/分块枚举答案x,暴力把除了最短的字符串以外的其他字符串的x长度子串哈希搞出来,分别扔到set里. 然后暴力枚举最短的字符串的x长度字串,查看是否在全部的set里出现过. #include&l ...