hive创建唯一标识列(自增id)

目录

一、需求

二、方法

1.row_number()

2.UUID

3.row_sequence()

三、对比


一、需求

在某一张 hive 表中需要有一列去唯一标识某一行,有些类似于MySQL中的自增ID

二、方法

1.row_number()

select row_number() OVER(ORDER BY RAND()) from table;

2.UUID

SELECT regexp_replace(reflect("java.util.UUID", "randomUUID"), "-", "") AS uniqe_id
from table;

3.row_sequence()

使用UDF函数row_sequence(),必须在Hive环境要有hive-contrib相关jar包

create temporary function row_sequence as 'org.apache.hadoop.hive.contrib.udf.UDFRowSequence';

执行查询语句

select row_sequence() from table;

三、对比

row_number函数是对整个数据集做处理,自增序列在当次排序中是连续的唯一的,使用 row_number() 容易发生数据倾斜;

使用UUID的方式可以解决数据倾斜,如果在hive表中null的值过多,也可以使用UUID的方法给null赋值,解决数据倾斜的问题;

UDF函数row_sequence()是按照任务排序,但是一个SQL可能并发执行的job不止一个,而每个job都会从1开始各自排序,不能保证序号全局唯一。

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值