增删改查功能怎么实现_Hive 实现增删改功能探索

Hive 不支持数据的update 和 delete, 有什么方法可以实现关系型数据库的增删改查功能,下面是自己的一点探索

主要从两个方面着手: 一是数据怎么存储? 二是数据怎么查询?

存储: 设置2层动态分区, record 的create_time 转换成day 作为第一层分区 和 record 更新记录标识flag作为第二层记录 (N-表示新记录, U-表示更新记录, D- 表示删除记录)

例如 一张 用户购买记录表test_user, 字段如下:

7043647e66b3e4625367a79faf95c6c3.png

(其中 day和f 表示分区字段)

假设 2019-01-01 有3条用户记录, 模拟数据生成的SQL 如下

e7f654eb4c4cab6fdeaac66eac9b3f92.png

生成数据如下

20d12bbe2b70e00ce5603e50f36d8e54.png

当在 2019-01-02 时间, 用户01 的金额 发生了变化 由 100 变成 150 模拟数据生成的SQL 如下

265d4630d1e094a8856846822c4251ae.png
假设 flag 已经处理成u

这时候 test_user 表 数据 变成如下:

a5ff20c6591b3ecfd167f4194aa6b967.png

当在 2019-01-02 时间, 用户02 的金额 发生了变化 由 200 变成 250, 用户03 的记录删除了 模拟数据生成的SQL 如下

36f2b9a11a4bb9a225c171b686586ef6.png

606ba03524d2e12783061b87d1630e59.png

这时候 test_user 表 数据 变成如下:

08414ca6e69ed5c6bd43b5b0f85e2f4d.png

现在要展示 用户 1,2,3 他们最终的状态, 查询SQL的写法

775b92415fe67509faa12accb8ad73e6.png

结果如下:

97916ca6d7d3440e5144a45ba08a592f.png
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值