当前位置: 首页 > news >正文

绵阳做网站百度客服中心人工在线

绵阳做网站,百度客服中心人工在线,外贸网络营销外包,网站建设管理概述在日常业务开发过程中,通常遇到需要hive数据表中生成一列唯一ID,当然连续递增的更好。 最近在结算业务中,需要在hive表中生成一列连续且唯一的账单ID,于是就了解生成唯一ID的方法 1. 利用row_number函数 语法:row_n…

在日常业务开发过程中,通常遇到需要hive数据表中生成一列唯一ID,当然连续递增的更好。

最近在结算业务中,需要在hive表中生成一列连续且唯一的账单ID,于是就了解生成唯一ID的方法

1. 利用row_number函数

语法:row_number() over(order by step)+start_num

step表示每次递增多少

start_num表示从哪个值开始递增,不写默认是0

如下:表示从10000开始,每次递增1

SELECT row_number() over(order by 1)+10000

因此输出是10001

如果有其他值,也可以拼接其它值,比如列date是20231010

SELECT CONCAT(date,row_number() over(order by 1)+10000) AS auto_increment_id

因此输出是2023101010001

2. 利用自定义函数序列

首先Hive环境要有hive-contrib相关jar包

定义函数row_sequence

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

使用函数row_sequence

SELECT row_sequence() AS auto_increment_id

row_sequence的自增规则是我们自己定义的,至于怎么定义,就看我们的逻辑是怎么实现

3、二者区别

第一种方法row_number

在一次SQL运行中是全局递增的,只不过再次执行SQL就会重复,如果不想重复我们可以更改start_num的值,把start_num调整到我们认为的不会重复的值开始

或者拼接上日期或者时间戳等前缀,这样每次执行就不会重复

第二种方法UDFRowSequence

由于是我们自己定义的函数,而SQL任务是以分布式的运行的,一个SQL并发可能会有多个job执行,每个job可以理解为1个节点或者进程,在每个进程上运营的序列都从起始值开始,所以不能保证序号全局连续唯一。因此我们可以借助第三方存储记录,比如Redis,来保证生产序列的全局连续递增

http://www.zhongyajixie.com/news/54110.html

相关文章:

  • 做网站全套500元上海做网站公司管理人员课程培训
  • dig网站开发跨境电商怎么开店铺
  • 芙蓉区乡建设局网站上海网络营销上海网络推广
  • 应聘ui设计师自我介绍windows优化大师会员
  • 怎么自己做免费网站新手怎么做网页
  • 网站开发后端待遇桔子seo
  • 商城网站 后台软文写作300字
  • seo百度网站排名软件app关键词推广
  • 建设厅网站的无法打印有了域名怎么建网站
  • 网站关键词排名100长沙seo男团
  • 重庆云阳网站建设公司推荐百度资源分享网
  • 做设计不能不知道的网站可以营销的十大产品
  • 礼品类网站建设策划方案seo的内容怎么优化
  • 大连市网站制作电话搜索百度
  • 大连金普新区规划建设局网站国际军事新闻今日头条
  • wordpress全站静态化seo网站推广软件
  • 淘宝式网站建设重庆seo网络推广关键词
  • 网站怎么投放广告写文的免费软件
  • 全球最火的十大游戏怎么优化百度关键词
  • 乔拓云建站网公司客服电话百度商务合作电话
  • 官方网站的必要性艾滋病多久可以查出来
  • 外贸b2b网站大全一b2b平台网上哪里可以免费打广告
  • 南昌网站建设资讯百度一下就一个
  • phpweb手机网站企业网站建设的目的
  • 衡水有做网站的吗泉州百度开户
  • b2c商城大全一个具体网站的seo优化方案
  • 做网站一般图片多大山东疫情最新消息
  • 网站备案注销怎么恢复淘宝seo是什么
  • 开封网站建设培训学校关键词的选取原则
  • 安徽省水利建设厅官方网站手机端竞价恶意点击