oracle行轉列函數WMSYS.WM_CONCAT 用法


1.通過 10g 所提供的 WMSYS.WM_CONCAT 函數即可以完成 行轉列的效果

select group_code, wm_concat(display_title) from DR_OPM_DATASET_RELATED
group by group_code

 

網上看到例子:

CREATE TABLE tab_name(ID INTEGER NOT NULL PRIMARY KEY,cName VARCHAR2(20));
CREATE TABLE tab_name2(ID INTEGER NOT NULL,pName VARCHAR2(20));
INSERT INTO tab_name(ID,cName) VALUES (1,'百度');
INSERT INTO tab_name(ID,cName) VALUES (2,'Google');
INSERT INTO tab_name(ID,cName) VALUES (3,'網易');
INSERT INTO tab_name2(ID,pName) VALUES (1,'研發部');
INSERT INTO tab_name2(ID,pName) VALUES (1,'市場部');
INSERT INTO tab_name2(ID,pName) VALUES (2,'研發部');
INSERT INTO tab_name2(ID,pName) VALUES (2,'平台架構');
INSERT INTO tab_name2(ID,pName) VALUES (3,'研發部');
COMMIT;

SELECT t1.ID,t1.cName,wmsys.wm_concat(t2.pName) FROM tab_name t1,tab_name2 t2 WHERE t1.ID=t2.ID GROUP BY t1.id,t1.cName;

 

期望結果:

ID cName pName

1 百度 研發部,市場部

2 Google 研發部 ,平台架構

3 網易 研發部

 

還有二種方法 也介紹下:

方法二:使用sys_connect_by_path

select id, cName, ltrim(max(sys_connect_by_path(pName, ',')), ',') from (select row_number() over(PARTITION by t1.id ORDER by cName) r,t1.*, t2.pName from tab_name t1, tab_name2 t2 where t1.id = t2.id)
start with r=1 CONNECT by prior r =r-1 and prior id = id group by id ,cName order by id;

方法三:使用自定義函數

create or replace function coltorow(midId INT) RETURN VARCHAR2 is
Result VARCHAR2(1000);
begin
FOR cur IN (SELECT pName FROM tab_name2 t2 WHERE midId=t2.id) LOOP
RESULT:=RESULT||cur.pName||',';
END LOOP;
RESULT:=rtrim(RESULT,',');
return(Result);
end coltorow;

SELECT t1.*,coltorow(t1.ID) FROM tab_name t1,tab_name2 t2 WHERE t1.ID=t2.ID GROUP BY t1.ID,t1.cname ORDER BY t1.ID;

 

GROUP BY 后面還有二個函數比較常用:

ROLLUP和CUBE 用法     
      Oracle的GROUP BY語句除了最基本的語法外,還支持ROLLUP和CUBE語句。如果是Group by  ROLLUP(A, B, C)的話,首先會對(A、B、C)進行GROUP BY,然后對(A、B)進行GROUP BY,然后是(A)進行GROUP BY,最后對全表進行GROUP BY操作。

      如果是GROUP BY CUBE(A, B, C),則首先會對(A、B、C)進行GROUP BY,然后依次是(A、B),(A、C),(A),(B、C),(B),(C),最后對全表進行GROUP BY操作。 grouping_id()可以美化效果。除了使用GROUPING函數,還可以使用GROUPING_ID來標識GROUP BY的結果。

       也可以 Group by Rollup(A,(B,C)) ,Group by A Rollup(B,C),…… 這樣任意按自己想要的形式結合統計數據,非常方便。

 

Rollup():分組函數可以理解為group by的精簡模式,具體分組模式如下:

  Rollup(a,b,c): (a,b,c),(a,b),(a),(全表)

Cube():分組函數也是以group by為基礎,具體分組模式如下:

  cube(a,b,c):(a,b,c),(a,b),(a,c),(b,c),(a),(b),(c),(全表)

 

 

引自:http://javasam.iteye.com/blog/1954176


免責聲明!

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



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