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

网站内容策略极致cms模板

网站内容策略,极致cms模板,泰安人才网官网登录,学校网站建设建议在日常业务开发过程中,通常遇到需要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/835651/

相关文章:

  • 深圳网站开发公司 有哪些电商网站建设建站方案
  • 济宁北湖旅游度假区建设局网站龙胜时代大厦 做网站
  • 湖南房地产加盟网站建设微信官方网站下载安装
  • 网站建设调查报告范文全国做网站的公司
  • 建网站的公司起什么名好海外社交平台推广
  • 查网站死链必用工具域名的种类及查询网站
  • 梅山建设局网站企业展厅怎么设计
  • php红酒网站建设精选网站建设
  • wordpress密码重置漏洞怎么给网站做优化
  • 锦州北京网站建设廊坊核酸检测结果
  • 美篇在哪个网站做的免费网站qq抓取
  • 大庆市建设局宫方网站郑州小程序开发哪家好
  • wordpress全站源码深圳做网站的地方
  • 网站建设相对路径国外以紫色为背景的网站
  • 展厅设计装修宁波厂家关键词优化
  • 网站做排名有用吗网站规划与建设
  • 怎样查网站备案人的联系方式怎么去做网站
  • 可以网站可以做免费的文案广告语上海高端网站开发
  • 成都学校网站建设手机网站开发常用工具
  • jquery 网站后台模板做网站要用什么服务器
  • 网站制作模板过程怎么样编辑wordpress
  • 没有网站可以做淘宝客吗做电影网站程序哪个好
  • 目录搜索引擎网站成品网站开发
  • wordpress设计类网站装修设计平台有哪些
  • 上海建材网站互联网十
  • 电话销售做网站推销厦门做网站公司哪家好
  • 怎样提高网站转化率在线设计平台哪个好用
  • php网站出现乱码网站制做公司
  • 网站按天扣费优化推广深圳学校网站建设
  • 网站界面设计的相关指南上海SEO网站优化推广公司