zoukankan      html  css  js  c++  java
  • 数据仓库中的拉链表

    Q1

    什么拉链表?

    拉链表,记录每条信息的生命周期,一旦一条记录的生命周期结束,就要重新开始一条新的记录,并把当前日期放入生效的开始日期;

    如果当前信息至今有效,在生效结束日期中填入一个极大值(一般为9999-99-99)

    数据仓库中的拉链表

     

    Q2

    为什么要建立拉链表?

    拉链表适合于:数据会发生变化,但是大部分是不变的;

    比如:订单信息从未支付、已支付、未发货、已完成等经历了一周,大部分时间是不变化的,只有状态和状态发生时间会有更改。如果数据量有一定的规模,无法按照每日全量的方式保存。

    数据仓库中的拉链表

     

    Q3

    如何使用拉链表?

    通过,生效开始日期<=某个日期 且 生效结束日期>=某个日期,能够得到某个时间点的数据全量切片

    1.拉链表数据

    数据仓库中的拉链表

     

    2.例如获取2019-01-01的历史切片:SELECT * FROM order_info where start_date<='2019-01-01' AND end_date>='2019-01-01'

    数据仓库中的拉链表

     

    3.例如获取2019-01-02的历史切片:SELECT * FROM order_info where start_date<='2019-01-02' AND end_date>='2019-01-02'

    数据仓库中的拉链表

     

    Q4

    拉链表的制作过程?

    订单当日全部数据和MySQL中每天变化的数据拼接在一起,形成一个新的临时拉链表数据。用临时拉链表覆盖旧的拉链表数据。

    数据仓库中的拉链表
  • 相关阅读:
    Ynoi 杂题选做
    CSP-S2021 浙江 游记
    P6272 [湖北省队互测2014]没有人的算术
    P5206 [WC2019]数树
    P5405 [CTS2019]氪金手游
    LOJ6679 Unknow
    LOJ3040 「JOISC 2019 Day4」合并
    P6122 [NEERC2016]Mole Tunnels
    三维凸包
    三,四元环计数
  • 原文地址:https://www.cnblogs.com/IT-Evan/p/13395085.html
Copyright © 2011-2022 走看看