Oracle--SQL技巧之二(多行記錄用逗號拼接在一起)


需求:

     目前接觸BI系統,由於業務系統的交易記錄有很多,常常有些主管需要看到所有的記錄情況,但是又不想滾動,想一眼就可以看到所有的,於是就想到了字符串拼接的形式。

解決方案:使用Oracle自帶的函數 WMSYS.WM_CONCAT,進行拼接。

函數限制:它的輸出不能超過4000個字節。

為了不讓SQL出錯,又可以滿足業務的需求,超過4000個字節的部分,使用“。。。”

實現SQL如下:

CREATE TABLE TMP_PRODUCT
(PRODUCT_TYPE VARCHAR2(255),
 PRODUCT_NAME VARCHAR2(255));
 
 
insert into tmp_product
select 'A','ProductA'||rownum from dual
connect by level < 100
union all
select 'B','ProductB'||rownum from dual
connect by level < 300
union all
select 'C','ProductC'||rownum from dual
connect by level < 400
union all
select 'D','ProductD'||rownum from dual
connect by level < 500
union all
select 'E','ProductE'||rownum from dual
connect by level < 600;


SELECT PRODUCT_TYPE,
       WM_CONCAT(PRODUCT_NAME) || MAX(STR) AS PRODUCT_MULTI_NAME
  FROM (SELECT PRODUCT_TYPE,
               PRODUCT_NAME,
               CASE
                 WHEN ALL_SUM > 4000 THEN
                  '...'
                 ELSE
                  NULL
               END AS STR
          FROM (SELECT PRODUCT_TYPE,
                       PRODUCT_NAME,
                       SUM(VSIZE(PRODUCT_NAME || ',')) OVER(PARTITION BY PRODUCT_TYPE) AS ALL_SUM,
                       SUM(VSIZE(PRODUCT_NAME || ',')) OVER(PARTITION BY PRODUCT_TYPE ORDER BY PRODUCT_NAME) AS UP_SUM
                  FROM TMP_PRODUCT)
         WHERE (UP_SUM <= 3998 AND ALL_SUM > 4000)
            OR ALL_SUM <= 4001)
 GROUP BY PRODUCT_TYPE


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM