码迷,mamicode.com
首页 > 数据库 > 详细

oracle 使用pivot 函数进行批量数据的动态行转列

时间:2019-07-23 13:37:35      阅读:450      评论:0      收藏:0      [点我收藏+]

标签:distinct   arc   RoCE   rom   varchar2   begin   for   exe   cut   

公司业务要求,需要对一批数据大批量地进行动态行转列之后进行分析,而pivot 函数in中不能使用子查询,有个方法是说可以通过动态sql拼接的方法实现, 在网上找了很久之后没找到具体的方法,就自己去摸索实现了。具体方法如下。

因为需要实现的是动态行转列,所以需要先用wm_concat(distinct())函数单独查出列名,再用dbms_lob.substr()将clob字段转成字符串。然后动态拼接得出的列名来进行查询。建个视图存放查询的结果就可以直接查需要的表啦。具体的代码如下:

PROCEDURE P_FXJG AS
     
    v_LM         VARCHAR2(2000);
    vs_sql        varchar2(6000); 
    vs_sql1       varchar2(6000);  
  
  BEGIN
  
    vs_sql1 := INSERT INTO LS_TEMP select  dbms_lob.substr(wm_concat(distinct(sf)))  from B_CLB  a  ;
    execute immediate vs_sql1;
  
    
    SELECT SFBM INTO V_LM FROM LS_TEMP; 
  
    vs_sql := create or replace view V_FXJG as select *  from (select a.YH, a.MC, a.LX "BZ", a.SF, a.JG from  B_CLB a  )  pivot(sum(JG) for SF in( ||
              V_LM || ));
    execute immediate vs_sql; 
    
  END;

 

oracle 使用pivot 函数进行批量数据的动态行转列

标签:distinct   arc   RoCE   rom   varchar2   begin   for   exe   cut   

原文地址:https://www.cnblogs.com/my-fishking/p/11230803.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!