我想处理 MySQL 数据仓库中的日期维度。 (我是DW世界的新手)
我用谷歌进行了一些搜索,看到了很多表结构(大部分)日期维度,其中主键是一个简单的UNSIGNED INTEGER
.
为什么不使用DATE
字段作为主键,因为对于 MySQL,它是 3 字节 VS 4 字节INTEGER
?
Ex:
CREATE TABLE dimDate
id INTEGER UNSIGNED NOT NULL PRIMARY AUTOI_NCREMENT,
date DATE NOT NULL,
dayOfWeek
...
VS
CREATE TABLE dimDate
date DATE NOT NULL PRIMARY,
dayOfWeek
...
日期维度有点特殊——主键具有日期(2011-12-07)或与日期相关的整数(20111207)实际上是首选。这允许对事实表进行良好的分区(按日期)。
对于其他类型的维度,建议使用代理(整数)键。
作为模板,每个维度通常都有以下条目unknown, not entered, error, ...
通常与钥匙相匹配0, -1, -2, ...
因此,更常见的是查找整数格式的日期(20111207)作为主键而不是日期 - 它表示起来有点混乱unknown, not entered, error, ...
带有日期类型的键。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)