oracle多行转多列

发布网友 发布时间:2022-04-22 20:42

我来回答

1个回答

热心网友 时间:2022-04-07 18:30

你这个应该是一张通用的表吧,就是说下面还有可能出现,诸如ID=10002或者10003等。
如果这样的话,就用row_number()over(partition by ID),进行排序,然后把排序后的再进行转换。
比如上面这个就是
select row_number()over(partition by ID) id_id,id,countnum from table
这样会出来结果,如下
id_id id countnum
1 10001 30
2 10001 40
3 10001 50
1 10002 20
2 10002 50
3 10002 30
上面的结果没有排序,也可以按照countnum进行排序,就是在partition by id的后面加一个orderby,看你用不用了。
然后再对这个结果进行行列转换,用case when就行,我假设上张表取别名为a
那么
select id,(case when id_id=1 then countnum end) column1,,(case when id_id=2 then countnum end) column2,(case when id_id=3 then countnum end) column3,(case when id_id=4 then countnum end) column3,........from a
不过这种写法有一个问题,就是必须写一个最长的,不然你就有数据不能显示出来。
如果只有一个10001,那么可以利用rownum直接编组。追问

执行您的sql语句得到

但我想要的效果是这样:  求大神解答

追答再group by sum一下不就出来了。
类似: sum((case when id_id=1 then countnum end)) column1。。。。。。。后面再group by id不就行了。

声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com