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