BI 前端实践 11:多维分析使用有层次的维度

本文介绍了在BI实践中如何处理具有层次关系的维度,如产品分类的多级类别和日期中的年、月、日。通过在元数据中定义维度层次,可以将隐含的维度明晰化,便于多维分析。文章详细阐述了如何在元数据中定义维度层次,使用SQL和假表来处理无直接关联的维度,以及如何在多维分析界面中应用这些定义。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

实践目标

有些维度有层次关系,比如产品的多级类别;年、月、日;国、省、市,这几个有层次关系的维度有可能存储在同一个字段中,比如005006008中包含了三级类别的编码,日期字段中则隐含了年维、月维。通过在语义层中预定义这些层次关系,把隐含的维度明晰定义出来,以方便界面中做多维分析。

认识维度的层次

修改测试库,给产品表增加分类ID引入日期两列。一个产品可以归类为一级类别、二级类别、三级类别三种,分类ID的编码特点是每3位代表一个级别。

各级分类的名称在产品分类表(product_category)中定义:

产品表中的分类字段,虽然存储的是三级类别的编码,但它能直接直接计算出一级、二级类别,相当于这一个维度字段实际上还隐含了一、二级类别这两个维度。日期字段,也有这个特点,实际上隐含着年份、季度、月份这些维度(再细分的话,还包含星期几、时、分、秒等相对不常用的维度)。

这些隐含的、可以被计算出来的新维度也就是维度的层次,简称维层。因为这些隐含的、有层次维在多维分析中也常用,所以有必要在元数据中预先定义出来。

最后再说明一下,这种用一个字段存储多个有层次的维度,并非唯一的库表设计方式,之所以存在,往往是为了简化设计。采用常规的独立维表设计时,三级类别分别存储在category1, category2, category3三个表中,通过外键关联:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值