- 拉链表
维护历史状态,以及最新状态数据的一种表,拉链表根据拉链粒度的不同,实际上相当于快照,只不过做了优化,去除了一部分不变的记录,通过拉链表可以很方便的还原出拉链时点的客户记录 - 拉链表的逻辑相对来说是有一定的难度,现在尝试改造了一种类似于拉链表的存储历史快照数据的方法,记录一下跟大家分享
- 举例示范
有一张体重数据表,每天都会有当天的所有人的体重信息,假如当前日期为20221002
20221001数据信息
| dte | name | weight |
|---|---|---|
| 20221001 | tom | 185 |
| 20221001 | rose | 98 |
| 20221001 | korry | 138 |
| 20221001 | jack | 126 |
20221002数据信息
| dte | name | weight |
|---|---|---|
| 20221002 | tom | 187 |
| 20221002 | rose | 98 |
| 20221002 | korry | 136 |
| 20221002 | jack | 126 |
现在假如20221001数据已经是数仓里面的历史数据,现在需要将20221002的数据更新进去,很明显只有tom和korry的体重发生变化。
数仓表为weightInfo_his
当天的表为weightInfo_cur
insert into weightInfo_his
select t1.dte, t1.name, t1.weight
from weightInfo_cur,
(
select t1.dte, t1.name, t1.weight
from weightInfo_his t1
join
(
select name,max(dte) as dte
from weightInfo_his
where dte <= current_date()
group by name
) t2
on t1.name=t2.name and t1.dte=t2.dte
) t2
where t1.name=t2.name and t1.weight<>t2.weight ;
更新完之后查询结果如下:
| dte | name | weight |
|---|---|---|
| 20221001 | tom | 185 |
| 20221001 | rose | 98 |
| 20221001 | korry | 138 |
| 20221001 | jack | 126 |
| 20221002 | tom | 187 |
| 20221002 | korry | 136 |
查询某个快捷日期当天的数据sql如下:
select t1.dte, t1.name, t1.weight
from weightInfo_his t1
join
(
select name,max(dte) as dte
from weightInfo_his
where dte <= $dte --dte为输入的快捷日期
group by name
) t2
on t1.name=t2.name and t1.dte=t2.dte
查询结果为:
| dte | name | weight |
|---|---|---|
| 20221001 | rose | 98 |
| 20221001 | jack | 126 |
| 20221002 | tom | 187 |
| 20221002 | korry | 136 |
这样不用拉链表也可以实现历史数据的存档了~
本文探讨了一种简化版的拉链表设计,用于存储和检索历史状态数据。通过对比不同日期的体重数据表,展示了如何仅更新变化的数据,从而节省存储空间。举例说明了如何在不使用传统拉链表的情况下,查询特定日期的数据快照,达到存档历史数据的目的。
8228

被折叠的 条评论
为什么被折叠?



