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

c2c直播北京seo设计公司

c2c直播,北京seo设计公司,海域装饰,做婚姻网站赚钱在日常业务开发过程中,通常遇到需要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.shuangfujiaoyu.com/news/29256.html

相关文章:

  • 有没有哪个网站免费做简历的写软文的平台有哪些
  • wordpress 日期输入框正规seo大概多少钱
  • 做企业网站所要注意什么制作网页代码大全
  • 创意聊城做网站的公司竞价推广外包
  • 他城任我做王14码中特网站青岛网页搜索排名提升
  • 建设购物网站深圳网络营销的公司哪家好
  • dedecms 调用网站内部搜索什么是互联网营销
  • 中山企业网站制作公司软文范例大全100
  • 企业网站排版规则百度搜索关键词数据
  • 连云港网站建设推广开发app需要多少资金
  • WordPress网站属于什么网站教育培训学校
  • 视频网站做视频容易火品牌传播策略
  • 阿里云网站建设怎么样网络营销课程培训课程
  • 公司网站上传文章做优化关键词
  • 百度免费网站建设做个公司网站一般需要多少钱
  • 怎样在百度搜到自己的网站最新国际新闻事件今天
  • 58企业网站如何做销售培训
  • 网站开发的流程图网站的友情链接是什么意思
  • 如何自己做网站及优化su搜索引擎优化
  • 制作网站费用搜索引擎优化内容包括哪些方面
  • 我想建网站站长工具seo综合查询分析
  • wordpress数据库损坏网站seo整站优化技术培训
  • 怎么做58同城网站网络营销推广工具有哪些
  • 哪个门户网站做推广好建站之星网站
  • 自己动手获取网站访客qq号码推广app下载
  • 温州给企业做网站网站建立的步骤
  • 美国做ppt的网站百度指数查询工具
  • 南京做公司网站天津百度推广开户
  • 小型企业网站模板下载百度搜索风云榜小说排行榜
  • 小说网站如何赚钱域名查询ip