如何把网站的文字编辑,WordPress配置阿里云cdn,榆林医疗网站建设,Wordpress可视化导航数据一行如何转多行
假如有一张表#xff0c;字段有两个#xff0c;分别是name 和 number#xff0c;代表含义为名字 和 名字出现的次数#xff0c;现在需要把一行数据转为number行
举例#xff1a; 输入#xff1a; tom#xff5c;3jery#xff5c;4输出#xff1a…数据一行如何转多行
假如有一张表字段有两个分别是name 和 number代表含义为名字 和 名字出现的次数现在需要把一行数据转为number行
举例 输入 tom3jery4输出 tomtomtomjeryjeryjeryjery思路分析
把一行数据炸成对应的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 numberunion 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