1 什么是拉链表
拉链表,
记录每条信息的生命周期为单位,
一旦条记录的生命周期结束,就重新开始一条新的记录,并把当前日期放入生效开始日期。
如果当前信息至今有效,在生效结束日期中填入一个极大值(如9999-99-99 或者 9999-12-31)。
2 为什么要做拉链表
1 、 需要查看某些业务信息的某一个时间点当日的信息 。
2 、 数据会发生变化,但是大部分是不变的。(无法做每日增量)
3、 数据量有一定规模,无法按照每日全量的方式保存。 (无法做每日全量)
3 拉链表的形成过程
订单变化表与之前的拉链表合并得到
如何使用拉链表
通过 某个日期>=生效开始日期 且 某个日期<=生效结束日期
能够得到某个时间点的数据全量切片。
比如
select * from order_info where start_date<=’2019-01-01’ and end_date>=’2019-01-01’
就会得到 2019-01-01的历史切片
select * from order_info where start_date<=’2019-01-02’ and end_date>=’2019-01-02’
就会得到 2019-01-02的历史切片