请教一个行列转置的问题,类似于excel中的透视表,下图中的数据,有办法用hive sql做出来吗?我能想到的方法是用多个union 把他们按照不同的职位合并到一起,还有其他的方法吗?
2条回答 默认 最新
关注
右边的6个列每2个列一组,加一个静态的职位字段,一共三个列,用union all拼接起来,再用字符串聚合把职位拼起来。这个方法应该是可用的。
至于用lateral view explode进行行列转换的方法,我晚上回去再研究下
弄出来了
---测试表 CREATE TABLE TEST_TABLE2 (gs varchar(1), zybh int,zyxm varchar(10), zgbh int,zgxm varchar(10), jlbh int,jlxm varchar(10)); ---测试数据 insert into TEST_TABLE2 (GS, ZYBH, ZYXM, ZGBH, ZGXM, JLBH, JLXM) values ('A', 1, '张三', 1, '张三', 2, '李四'); insert into TEST_TABLE2 (GS, ZYBH, ZYXM, ZGBH, ZGXM, JLBH, JLXM) values ('A', 3, '王五', 4, '赵六', 3, '王五'); ---查询sql select gs ,xcode ,rcode ,concat_ws(',',collect_set(substr(rname,1,2))) as zw from ( select gs, map("ZYBH", ZYBH , "ZGBH", ZGBH , "JLBH", JLBH) as rybh,map("ZYXM", ZYXM , "ZGXM", ZGXM , "JLXM", JLXM) as ryxm from TEST_TABLE2 ) x lateral view explode(rybh) exptbl1 as rname, rcode lateral view explode(ryxm) exptbl1 as xname, xcode where substr(rname,1,2)=substr(xname,1,2) group by gs,xcode,rcode
实测截图
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报 编辑记录
悬赏问题
- ¥15 metadata提取的PDF元数据,如何转换为一个Excel
- ¥15 关于arduino编程toCharArray()函数的使用
- ¥100 vc++混合CEF采用CLR方式编译报错
- ¥15 coze 的插件输入飞书多维表格 app_token 后一直显示错误,如何解决?
- ¥15 vite+vue3+plyr播放本地public文件夹下视频无法加载
- ¥15 c#逐行读取txt文本,但是每一行里面数据之间空格数量不同
- ¥50 如何openEuler 22.03上安装配置drbd
- ¥20 ING91680C BLE5.3 芯片怎么实现串口收发数据
- ¥15 无线连接树莓派,无法执行update,如何解决?(相关搜索:软件下载)
- ¥15 Windows11, backspace, enter, space键失灵