初学Oracle UNPIVOT,PIVOT,WMSYS.WM_CONCAT三个函数
admin
2023-05-08 07:42:02
0

最近有接触到Oracle UNPIVOT,PIVOT,WMSYS.WM_CONCAT,以免忘记,整理如下:

--------------------------------------

UNPIVOT的用法:

原始资料如下图:

初学Oracle UNPIVOT,PIVOT,WMSYS.WM_CONCAT三个函数

现在要将资料转换成如下格式:

初学Oracle UNPIVOT,PIVOT,WMSYS.WM_CONCAT三个函数

将资料按照INQTY,OUTQTY,REMAININGQTY三个栏位进行列转行的处理.实现上面的转换,使用的函数是UNPIVOT,具体实现代码如下:

SELECT WEEKLY, ML, CVE, ITEMS, ITEM, QUANTITY

  FROM TESTP UNPIVOT(QUANTITY FOR ITEM IN(INQTY, OUTQTY, remainingqty))

 WHERE ID = '1';

-----------------------------------------------

PIVOT的用法:

如果原始资料是如下图这样:

初学Oracle UNPIVOT,PIVOT,WMSYS.WM_CONCAT三个函数

希望资料按照如下图片显示:

初学Oracle UNPIVOT,PIVOT,WMSYS.WM_CONCAT三个函数

首先将资料根据INQTY,OUTQTY,REMAININGQTY三个栏位进行列转行的处理,然后再根据Weekly栏位做行转列的处理.具体实现代码如下:

SELECT *

  FROM (SELECT WEEKLY, ML, CVE, ITEMS, ITEM, QUANTITY

           FROM TESTP UNPIVOT(QUANTITY FOR ITEM IN(INQTY,OUTQTY,remainingqty))

          WHERE ID = '1') PIVOT(SUM(QUANTITY) FOR WEEKLY IN('W150826','W150827'))

 ORDER BY ML, CVE, ITEMS;

需要注意的是,PIVOT函数中的红色字体部分只能是聚合函数,绿色字体部分不能是动态的字串[就是不能直接填写一个栏位放在该处].

--------------------------------------------

WMSYS.WM_CONCAT的用法:

原始资料如下图:

初学Oracle UNPIVOT,PIVOT,WMSYS.WM_CONCAT三个函数

希望资料按ID,WEEKLY,ML,CVE group by 汇总,多个items以逗号分隔,显示在一个单元格里面:

初学Oracle UNPIVOT,PIVOT,WMSYS.WM_CONCAT三个函数

具体实现代码如下:

 SELECT ID, weekly, ml, cve, to_char(WMSYS.WM_CONCAT(items))

   FROM TESTP

  WHERE ID = '1'

  GROUP BY ID, weekly, ml, cve

  ORDER BY weekly;










相关内容

热门资讯

跳河救人的外卖小哥找到了! 外... 5月12日下午5时许,漯河市郾城区孟庙镇幸福渠河堤旁,57岁的甘女士蹲在河边打水,准备回家给鱼换水,...
今年以来,越来越多美国交流团来... 4月,数十名美国犹他州青少年来豫参加2026年YES项目交流活动。图为美国青少年在郑州体验书法项目。...
“打工机器人”亮相郑州街头 机器人服务员“小盖”在郑州街边的一零售店工作。 王磊 摄机器人当服务员,在街头卖咖啡——这不是科幻电...
打响“河南服务”品牌丨盾构机有... 【开栏的话】为深入贯彻落实全省服务业大会精神,本报即日起开设“打响‘河南服务&rsquo...
一季度我国数字产业收入9.5万... 【大河财立方消息】5月14日,工信部发布的数据显示,一季度,我国数字产业实现良好开局,行业利润大幅改...
一体推进整治形式主义为基层减负... 形式主义实质是主观主义、功利主义,根源是政绩观错位、责任心缺失。当前,各地以深化“六个纠治”为抓手,...
5月上旬汽油柴油价格环比继续下... 【大河财立方消息】 5月14日,国家统计局发布2026年5月上旬流通领域重要生产资料市场价格变动情况...
河南信阳凌晨通报:常某朋(男,... 2026年5月13日21时43分许,我市浉河区发生一起道路交通事故。经查,常某朋(男,40岁)驾驶私...
马化腾回应腾讯AI是否落后;曝... “IT早报”时间,大家好,现在是 2026 年 5 月 14 日星期四,今天的重要科技资讯有: 1、...
马斯克宣布xAI将终止独立运营... 5月7日凌晨,马斯克在X上发布消息称旗下人工智能公司xAI将终止独立运营。马斯克表示,xAI将整体并...