百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程字典 > 正文

拉链表(拉链表英文)

toyiye 2024-09-12 20:48 2 浏览 0 评论

定义

拉链表是一种数据模型,主要是针对数据仓库设计中表存储数据的方式而定义的,顾名思义,所谓拉链,就是记录历史。记录一个事物从开始,一直到当前状态的所有变化的信息。拉链表可以避免按每一天存储所有记录造成的海量存储问题,同时也是处理缓慢变化数据(SCD2)的一种常见方式。

用途

1. 数据量比较大
2. 表中的部分字段会被update,如用户的地址,产品的描述信息,订单的状态等等
3. 需要查看某一个时间点或者时间段的历史快照信息,比如,查看某一个订单在历史某一个时间点的状态,比如,查看某一个用户在过去某一段时间内,更新过几次等等
4. 变化的比例和频率不是很大,比如,总共有1000万的会员,每天新增和发生变化的有10万左右
5. 如果对这边表每天都保留一份全量,那么每次全量中会保存很多不变的信息,对存储是极大的浪费

拉链历史表,既能满足反应数据的历史状态,又可以最大程度的节省存储

案例一(历史表不是分区表)

1. 涉及到的表
1.1 业务表:
create table info(
sid int,
sname varchar(12),
address varchar(23),
create_time varchar(12),
update_time varchar(12)
);
1.2 hive 接收业务系统数据表
drop table if  exists ods_info_for;
create table if not exists ods_info_for(
sid int,
sname varchar(12),
address varchar(23),
create_time varchar(12),
update_time varchar(12)
)
ROW FORMAT DELIMITED
FIELDS TERMINATED BY ','
STORED as textfile
;
1.3 hive 分离出业务系统数据变化表(业务新增/修改的数据)
drop table if  exists ods_info_add;
create table if not exists ods_info_add(
sid int,
sname varchar(12),
address varchar(23),
create_time varchar(12),
update_time varchar(12),
start_time varchar(12),
end_time varchar(12)
)
ROW FORMAT DELIMITED
FIELDS TERMINATED BY ','
STORED as textfile
;
1.4 hive 存储历史数据变化表
drop table if  exists ods_info_his;
create table if not exists ods_info_his(
sid int,
sname varchar(12),
address varchar(23),
create_time varchar(12),
update_time varchar(12),
start_time varchar(12),
end_time varchar(12)
)
ROW FORMAT DELIMITED
FIELDS TERMINATED BY ','
STORED as textfile
;
2. 数据流转
业务数据 : 
info.txt
1,张三,北京,2020-10-20,2021-05-30
2,李四,上海,2021-03-05,2021-03-05
3,王五,广州,2021-08-25,2021-09-02
4,赵六,深圳,2021-09-23,2021-09-25

2.1 加载数据到 ods 外部表中
load data local inpath '/opt/info.txt' into table demo.ods_info_for; 

2.1 第一次全量同步
	insert into ods_info_his(sid, sname, address, create_time, update_time, start_time,end_time )   select sid, sname, address, create_time, update_time,current_date() start_time,'9999-12-31' end_time from ods_info_for ;
1	张三	北京	2020-10-20	2021-05-30	2024-04-07	9999-12-31
2	李四	上海	2021-03-05	2021-03-05	2024-04-07	9999-12-31
3	王五	广州	2021-08-25	2021-09-02	2024-04-07	9999-12-31
4	赵六	深圳	2021-09-23	2021-09-25	2024-04-07	9999-12-31

2.2 往后增量同步数据
2.2.1 变化数据
2	李四	哈尔滨	2021-03-05	2024-04-07
5	田七	南京	2021-09-26	2024-04-07

2.2.2 加载数据到 ods 外部表中
load data local inpath '/opt/info_add.txt' overwrite into table demo.ods_info_for; 

2.2.3 剥离变化数据(新增/修改)到 ods_info_add 表中
insert overwrite table ods_info_add select *,update_time start_time,'9999-12-31' end_time from ods_info_for where Create_time='2024-04-07' or Update_time='2024-04-07' ;
2	李四	哈尔滨	2021-03-05	2024-04-07	2024-04-07	9999-12-31
5	田七	南京	2021-09-26	2024-04-07	2024-04-07	9999-12-31

2.2.4 获取 ods_info_for 表数据并与 ods_info_add 表数据做左关联,将关联上数据 end_time 字段值改成 右表 update_time 字段值
select h.sid,  h.sname,  h.address,  h.create_time,  h.update_time,h.start_time 
 ,if(h.end_time='9999-12-31' and i.sid is not null,i.update_time ,h.end_time) as End_time
from ods_info_add i right join ods_info_his h  on i.sid = h.sid ;
1	张三	北京	2020-10-20	2021-05-30	2024-04-07	9999-12-31
2	李四	上海	2021-03-05	2021-03-05	2024-04-07	2024-04-07
3	王五	广州	2021-08-25	2021-09-02	2024-04-07	9999-12-31
4	赵六	深圳	2021-09-23	2021-09-25	2024-04-07	9999-12-31

2.2.5 将 2.2.4 步骤获取的数据 与 ods_info_add 表做 UNION all 数据合并
1	张三	北京	2020-10-20	2021-05-30	2024-04-07	9999-12-31
2	李四	上海	2021-03-05	2021-03-05	2024-04-07	2024-04-07
2	李四	哈尔滨	2021-03-05	2024-04-07	2024-04-07	9999-12-31
3	王五	广州	2021-08-25	2021-09-02	2024-04-07	9999-12-31
4	赵六	深圳	2021-09-23	2021-09-25	2024-04-07	9999-12-31
5	田七	南京	2021-09-26	2024-04-07	2024-04-07	9999-12-31

2.2.6 将 2.2.5 合并后的数据复写到 ods_info_his 表中
insert overwrite table ods_info_his 
select h.sid,  h.sname,  h.address,  h.create_time,  h.update_time,h.start_time 
 ,if(h.end_time='9999-12-31' and i.sid is not null,i.update_time ,h.end_time) as end_time
from ods_info_add i right join ods_info_his h  on i.sid = h.sid 
union all
select * from ods_info_add ;

3. 整理流程
第一次同步数据到历史表 : 
将从业务系统获取的数据后面添加 start_time 和 end_time 两个字段,然后将数据同步到 历史表(ods_info_his)中;
  start_time 值为任务同步的当天时间; 
  end_time 值为 '9999-12-31' 固定值;

往后再次从业务系统获取数据 :
1. 获取变化数据(新增/修改) 添加 start_time 和 end_time 两个字段,然后将数据同步到 记录数据变化表(ods_info_add)中;
  start_time 值为任务同步的当天时间; 
  end_time 值为 '9999-12-31' 固定值;
2. 通过 ods_info_his 与 ods_info_add 进行左关联,获取 ods_info_his 表数据,将关联上的数据中 end_time 改成 ods_info_add 表中 update_time 字段值;
3. 将 2 获取的数据 与 ods_info_add 表进行 union all 数据合并;
3. 将 3 合并后的数据复写到 ods_info_his 表中;

相关推荐

如何用 coco 数据集训练 Detectron2 模型?

随着最新的Pythorc1.3版本的发布,下一代完全重写了它以前的目标检测框架,新的目标检测框架被称为Detectron2。本教程将通过使用自定义coco数据集训练实例分割模型,帮助你开始使...

CICD联动阿里云容器服务Kubernetes实践之Bamboo篇

本文档以构建一个Java软件项目并部署到阿里云容器服务的Kubernetes集群为例说明如何使用Bamboo在阿里云Kubernetes服务上运行RemoteAgents并在agents上...

Open3D-ML点云语义分割实验【RandLA-Net】

作为点云Open3D-ML实验的一部分,我撰写了文章解释如何使用Tensorflow和PyTorch支持安装此库。为了测试安装,我解释了如何运行一个简单的Python脚本来可视化名为...

清理系统不用第三方工具(系统自带清理软件效果好不?)

清理优化系统一定要借助于优化工具吗?其实,手动优化系统也没有那么神秘,掌握了方法和技巧,系统清理也是一件简单和随心的事。一方面要为每一个可能产生累赘的文件找到清理的方法,另一方面要寻找能够提高工作效率...

【信创】联想开先终端开机不显示grub界面的修改方法

原文链接:【信创】联想开先终端开机不显示grub界面的修改方法...

如意玲珑成熟度再提升,三大发行版支持教程来啦!

前期,我们已分别发布如意玲珑在deepinV23与UOSV20、openEuler24.03发行版的操作指南,本文,我们将为大家详细介绍Ubuntu24.04、Debian12、op...

118种常见的多媒体文件格式(英文简写)

MP4[?mpi?f??]-MPEG-4Part14(MPEG-4第14部分)AVI[e?vi??a?]-AudioVideoInterleave(音视频交错)MOV[m...

密码丢了急上火?码住7种console密码紧急恢复方式!

身为攻城狮的你,...

CSGO丨CS2的cfg指令代码分享(csgo自己的cfg在哪里?config文件位置在哪?)

?...

使用open SSL生成局域网IP地址证书

某些特殊情况下,用户内网访问多可文档管理系统时需要启用SSL传输加密功能,但只有IP,没有域名和证书。这种情况下多可提供了一种免费可行的方式,通过openSSL生成免费证书。此方法生成证书浏览器会提示...

Python中加载配置文件(python怎么加载程序包)

我们在做开发的时候经常要使用配置文件,那么配置文件的加载就需要我们提前考虑,再不使用任何框架的情况下,我们通常会有两种解决办法:完整加载将所有配置信息一次性写入单一配置文件.部分加载将常用配置信息写...

python开发项目,不得不了解的.cfg配置文件

安装软件时,经常会见到后缀为.cfg、.ini的文件,一般我们不用管,只要不删就行。因为这些是程序安装、运行时需要用到的配置文件。但对开发者来说,这种文件是怎么回事就必须搞清了。本文从.cfg文件的创...

瑞芯微RK3568鸿蒙开发板OpenHarmony系统修改cfg文件权限方法

本文适用OpenHarmony开源鸿蒙系统,本次使用的是开源鸿蒙主板,搭载瑞芯微RK3568芯片。深圳触觉智能专注研发生产OpenHarmony开源鸿蒙硬件,包括核心板、开发板、嵌入式主板,工控整机等...

Python9:图像风格迁移-使用阿里的接口

先不多说,直接上结果图。#!/usr/bin/envpython#coding=utf-8importosfromaliyunsdkcore.clientimportAcsClient...

Python带你打造个性化的图片文字识别

我们的目标:从CSV文件读取用户的文件信息,并将文件名称修改为姓名格式的中文名称,进行规范资料整理,从而实现快速对多个文件进行重命名。最终效果:将原来无规律的文件名重命名为以姓名为名称的文件。技术点:...

取消回复欢迎 发表评论:

请填写验证码