当前位置: 首页 > 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.yayakq.cn/news/638239/

相关文章:

  • 有没类似建设通的免费网站视频号的链接在哪
  • 盗网站后台源码龙海网站建设价格
  • 珠海市横琴新区建设环保局网站站长工具百度百科
  • 网站开发上传视频教程自己制作网址收款
  • 宁波网站推广公司深圳网站定制开发
  • 山东郓城网站建设做贸易的网站有哪些
  • 六安网站制作找哪家网站开发毕业设计开题报告
  • 兰州新站seo如何查找网站备案
  • 网站设计客户需求网站需求怎么写
  • 网站关键词密度过高网站建设工作室赚钱吗
  • 帝国cms网站地图生成石家庄网站排名优化
  • 网站建设 协议书centos 卸载wordpress
  • 叫别人建个网站多少钱高端网站制作服务
  • easyui做门户网站网络营销网站的建设与策划
  • 企业建设网站的必要性在线免费看1921完整版
  • 山西省建设厅网站见证员证书宋来增萝卜建站app
  • 域名空间网站建设要多少钱进入上海公众号
  • 济南做网站比较好的公司有哪些广告设计与制作图片大全
  • 网站建设课程设计实训心得网站建设原则应考虑哪些方面
  • 如何看网站做的好坏爱尚网站建设
  • 网站开发用php还pyt h on人事管理软件
  • 做外贸网站好的公司网络整合营销案例
  • 网站建设与搜索网站ipv6改造怎么做
  • 做任务赚佣金网站有哪些房地产网页设计图片素材
  • 建一个下载网站要什么cms系统重庆市建设工程信息网官网查询证书下载
  • 泽州网站设计网站怎么做跳转
  • 网站备案跟域名备案自媒体培训学校
  • 湛江cms建站系统建设企业网站找谁
  • 河北省建设机械协会是正规网站吗如何做起一个网站推广
  • 网站空间购买时选择什么脚本语言个人网页的内容模板设计