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

Hive进阶函数:SPACE() 一行炸裂指定行

数据一行如何转多行

假如有一张表,字段有两个,分别是name 和 number,代表含义为名字 和 名字出现的次数,现在需要把一行数据转为number行

举例:

输入:

        tom|3

        jery|4

输出:

      tom

      tom

      tom

      jery

      jery

      jery

      jery
思路分析:

把一行数据炸成对应的number行,类似于列传行,列传行常用的函数为explode,但是要传入一个数组,函数会根据数组把列变为行,所以现在如果有一个数组,里面分别有number元素就可以实现上述的例子

引入函数

space函数:space函数需要传入一个数值n,则会生成n个数组

输入:
    space(3)
输出
    '   '  -- 三个空格

那么生成number个空格,再按照空格切割

输入:
    split(space(3), ' ')
输出:
    '"","","",""'

注意 :因为切割时候一个空格会切割为左右两个空串,所以在生成空格时,仅需要number-1个即可

实现:

在理清思路和了解方法后,就可以实现了,按照上面的例子

select 
    name
from tbl
lateral view exploed(split(space(number-1), ' ') tmp as num

全部代码

with base as (
  select 'tom' as name, 3 as number
  union all 
  select 'jery' as name, 4 as number 
)

select 
  name
from base 
lateral view explode(split(space(number - 1), ' ')) tmp as num 

结果

name
tom
tom
tom
jery
jery
jery
jery

http://www.kler.cn/a/148681.html

相关文章:

  • 人才流失预测模型(机器学习)
  • c语言中联合Union的作用及示例代码说明
  • Logrus入门
  • 【MatLab手记】 --从0到了解超超超详过程!!!
  • 在使用element中的抽屉<el-drawer>页签<el-tabs/>组合时,echarts图表宽度显示异常问题
  • 几个docker可用的镜像源
  • 【栈和队列(1)(逆波兰表达式)】
  • Ps:子路径的上下排列以及对齐与分布
  • 【开发实践】使用POI实现导出带有复杂表头的的excel文件
  • 璞华大数据产品入选中国信通院“铸基计划”
  • 【开源】基于Vue+SpringBoot的学校热点新闻推送系统
  • 梦极光(ez_re???)
  • MYSQL基础知识之【LIKE子句的使用 ,NULL值的处理,空值的处理】
  • ArrayList和顺序表
  • 服务器中深度学习环境的配置
  • 使用OSS搭建私有云内网yum仓库的方法
  • 盖茨表示GPT-5不会比GPT-4有太大改进;Intro to Large Language Models
  • 羽隔已就之图像处理之BP神经网络入门
  • C++ day36 贪心算法 无重叠区间 划分字母区间 合并区间
  • 计算机网络高频面试八股文
  • 解决Hadoop DataNode ‘Incompatible clusterIDs‘报错
  • 关于Unity中字典在Inspector的显示
  • 一、Lua基础
  • 【C++ 程序设计入门基础】- 第3节-循环结构01
  • Linux配置路由功能及添加静态路由
  • 免费查找文献期刊数据论文网站