数据一行如何转多行
假如有一张表,字段有两个,分别是name 和 number,代表含义为名字 和 名字出现的次数,现在需要把一行数据转为number行
举例:
输入:
tom|3 jery|4
输出:
tom tom tom jery jery jery jery
思路分析:
把一行数据炸成对应的number行,类似于列传行,列传行常用的函数为explode,但是要传入一个数组,函数会根据数组把列变为行,所以现在如果有一个数组,里面分别有number元素就可以实现上述的例子
引入函数
space函数:space函数需要传入一个数值n,则会生成n个数组
sql
输入:
space(3)
输出
' ' -- 三个空格
那么生成number个空格,再按照空格切割
sql
输入:
split(space(3), ' ')
输出:
'"","","",""'
注意 :因为切割时候一个空格会切割为左右两个空串,所以在生成空格时,仅需要number-1个即可
实现:
在理清思路和了解方法后,就可以实现了,按照上面的例子
sql
select
name
from tbl
lateral view exploed(split(space(number-1), ' ') tmp as num
全部代码
sql
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
结果
sql
name
tom
tom
tom
jery
jery
jery
jery