当前位置: 代码迷 >> Oracle技术 >> oracle列转行的有关问题()
  详细解决方案

oracle列转行的有关问题()

热度:362   发布时间:2016-04-24 08:41:41.0
oracle列转行的问题(在线等)
客户 帐龄1 帐龄2 帐龄3
A客户 15 45 75
A客户 20 50 80

转换成 
客户 帐龄
A客户 15
A客户 45
A客户 75
A客户 20
A客户 50
A客户 80


请问需要怎么写?

------解决方案--------------------
SQL code
select 客户,帐龄1 from 表union allselect 客户,帐龄2 from 表union allselect 客户,帐龄3 from 表
------解决方案--------------------
http://zhidao.baidu.com/question/170746889.html
------解决方案--------------------
SQL code
selelect 客户,帐龄1 AS 帐龄,帐龄類型='帐龄1' FROM Tablenameselelect 客户,帐龄2    AS 帐龄,帐龄類型='帐龄2' FROM Tablenameselelect 客户,帐龄3 AS 帐龄,帐龄類型='帐龄3'FROM Tablename
------解决方案--------------------
改改,輸入法太快亂來了,看看是否為這樣
SQL code
SELECT  客户,帐龄1 AS 帐龄,帐龄類型='帐龄1' FROM Tablename UNION ALL SELECT 客户,帐龄2    AS 帐龄,帐龄類型='帐龄2' FROM Tablename UNION ALL SELECT 客户,帐龄3 AS 帐龄,帐龄類型='帐龄3'FROM Tablename
------解决方案--------------------
SQL code
--方法 1:with tbl as(    select 'A客户' as "客户", 15 as "账龄1", 45 as "账龄2", 75 as "账龄3" from dual     union all    select 'A客户' as "客户", 20 as "账龄1", 50 as "账龄2", 80 as "账龄3" from dual)select "客户", "账龄1" as "账龄" from tbl union allselect "客户", "账龄2" from tbl union allselect "客户", "账龄3" from tbl;客户            账龄------- ----------A客户           15A客户           20A客户           45A客户           50A客户           75A客户           80--方法 2:with tbl as(    select 'A客户' as "客户", 15 as "账龄1", 45 as "账龄2", 75 as "账龄3" from dual     union all    select 'A客户' as "客户", 20 as "账龄1", 50 as "账龄2", 80 as "账龄3" from dual)select "客户", regexp_substr("账龄", '[^,]+', 1, line) as "账龄"  from (select "客户", "账龄1" || ',' || "账龄2" || ',' || "账龄3" as "账龄" from tbl) t1,       (select rownum as line from dual connect by rownum <= 3) t2 where regexp_substr("账龄", '[^,]+', 1, line) is not null;客户    账龄   ------- -------A客户   15     A客户   20     A客户   45     A客户   50     A客户   75     A客户   80
------解决方案--------------------
用Case吧
select case when ... then ... end case from Tablename
  相关解决方案