指标是一个统称概念,可以细分为 原子指标 和 派生指标 。 以 某企业近一周上海地域的销售金额 为例,整体是一个派生指标,其中的 销售金额 是原子指标; 近一周 是时间, 企业 和 地域 是维度。
可见,指标数据由三部分组成:
其中,维度可以是一个或多个,也可以是零个,简称为多维。
典型的关系型数据库就是 MySQL 。
使用时,需要先根据业务设计好数据模式:
然后,创建相应的数据库和数据表;最后,存储业务数据。
关系型数据库会有一个特殊的约定 :数据模式是相对固定的。业务不发生变化的情况下,数据模式不会轻易发生变化。
不同的业务会有不同的指标,每一个业务可以单独创建一个数据库,这个比较好理解。
每一个指标都会有时间和数值,但是不同的指标之间,它们的维度名称和维度数目却可能是不同的。
最直接的设计:
假设某个指标有三个维度:a、b 和 c,表结构如下所示:
timestamp |
a |
b |
c |
value |
2022-09-15 00:00:00 |
a1 |
b1 |
c1 |
1 |
2022-09-15 01:00:00 |
a2 |
b2 |
c2 |
2 |
2022-09-15 02:00:00 |
a3 |
b3 |
c3 |
3 |
timestamp 表示时间,value 表示数值,a、b 和 c 表示维度。
问题很明显:
受限于业务方的部署环境,仅支持关系型数据库 MySQL;而且业务方不能接收一个业务指标一个数据表的粗暴设计。
业务指标的数目是不可控的,但业务指标的维度数目是相对可控的,我们是否可以按维度数目创建 指标表 ,毕竟绝大多数数据可视化组件最多支持三维。
比如:
假设维度数目为 3 的指标表,表结构如下所示:
id |
timestamp |
d1 |
d2 |
d3 |
value |
m1 |
2022-09-15 00:00:00 |
a1 |
b1 |
c1 |
1 |
m2 |
2022-09-15 01:00:00 |
a2 |
b2 |
c2 |
2 |
m3 |
2022-09-15 02:00:00 |
a3 |
b3 |
c3 |
3 |
id 表示指标 ID,用于唯一标识指标;d1 、d2 和 d3 分别表示维度1、维度2 和 维度3。
一张数据表中可以存储多个相同维度数目指标的数据,如:m1、m2 和 m3。存储指标数据时,只要按指标的维度数目,将指标数据存储到相应维度数目的指标表中即可。指标表可以根据业务可能的最大维度数目预先创建,业务维度数目需要扩展时,仅需要新增有限的几张特定维度数目的指标表即可。
指标有维度的情况下,指标表仅支持按指标维度次序,依次存储和查询维度1、维度2、... 的维度数据,并不知道具体的维度名称是什么。
考虑到业务希望指标发生变化时,历史数据可追溯,同一个指标需要有多个版本。
也就是说,我们需要知道:
我们可以:
id |
version |
m1 |
1 |
m2 |
1 |
m1 |
3 |
id 表示指标 ID,version 表示版本号。
版本表存储着指标和版本的对应关系,可以查询指标的历史版本记录,也可以查询指标的最新版本。
id |
version |
name |
m1 |
3 |
a1 |
m1 |
3 |
a2 |
m1 |
3 |
a3 |
id 表示指标 ID,version 表示版本号,name 表示维度名称。
维度表存储着指标/版本和维度名称的对应关系,可以按指标 ID 和指标版本查询维度名称列表,多个维度名称的顺序按维度名称存储顺序依次排列。
id |
version |
timestamp |
d1 |
d2 |
d3 |
value |
m1 |
3 |
2022-09-15 00:00:00 |
a1 |
b1 |
c1 |
1 |
m1 |
3 |
2022-09-15 01:00:00 |
a2 |
b2 |
c2 |
2 |
m1 |
3 |
2022-09-15 02:00:00 |
a3 |
b3 |
c3 |
3 |
指标表存储着指标数据。注意,维度1、维度2 和 维度 N 的表现形式。
新增指标时,使用 Unix 时间戳作为版本号,存储指标 ID 和 版本至版本表;如果指标有维度,存储指标ID、版本号 和维度名称至维度表,如果维度有多个,需要按照维度排列顺序依次存储多条记录。
修改指标时,如果修改后的指标维度名称列表和维度表中该指标最新版本的维度名称列表数目或内容不一致,需要和新增指标一样,存储该指标新的版本号和维度名称列表。
存储指标数据时,获取维度表中该指标最新版本的维度名称列表,即可知指标维度数目;根据维度数目选取指标表,将指标数据存储至该指标表,维度名称需按顺序依次存储至维度1、维度2、...。
当前文章:关系型数据库存储多维指标数据
标题网址:http://www.csdahua.cn/qtweb/news4/361304.html
网站建设、网络推广公司-快上网,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 快上网