oracle列转行的问题(在线等)
时间:2011-10-21
来源:互联网
A客户 15 45 75
A客户 20 50 80
转换成
客户 帐龄
A客户 15
A客户 45
A客户 75
A客户 20
A客户 50
A客户 80
请问需要怎么写?
作者: linchenxi 发布时间: 2011-10-21
select 客户,帐龄1 from 表 union all select 客户,帐龄2 from 表 union all select 客户,帐龄3 from 表
作者: cosio 发布时间: 2011-10-21
作者: tiangtangcao 发布时间: 2011-10-21
selelect 客户,帐龄1 AS 帐龄,帐龄類型='帐龄1' FROM Tablename selelect 客户,帐龄2 AS 帐龄,帐龄類型='帐龄2' FROM Tablename selelect 客户,帐龄3 AS 帐龄,帐龄類型='帐龄3'FROM Tablename
作者: roy_88 发布时间: 2011-10-21
SQL code
SELECT 客户,帐龄1 AS 帐龄,帐龄類型='帐龄1' FROM Tablename UNION ALL SELECT 客户,帐龄2 AS 帐龄,帐龄類型='帐龄2' FROM Tablename UNION ALL SELECT 客户,帐龄3 AS 帐龄,帐龄類型='帐龄3'FROM Tablename
作者: roy_88 发布时间: 2011-10-21
--方法 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 all select "客户", "账龄2" from tbl union all select "客户", "账龄3" from tbl; 客户 账龄 ------- ---------- A客户 15 A客户 20 A客户 45 A客户 50 A客户 75 A客户 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
作者: opps_zhou 发布时间: 2011-10-21
select case when ... then ... end case from Tablename
作者: zergwangcn 发布时间: 2011-10-21
热门阅读
-
office 2019专业增强版最新2021版激活秘钥/序列号/激活码推荐 附激活工具
阅读:74
-
如何安装mysql8.0
阅读:31
-
Word快速设置标题样式步骤详解
阅读:28
-
20+道必知必会的Vue面试题(附答案解析)
阅读:37
-
HTML如何制作表单
阅读:22
-
百词斩可以改天数吗?当然可以,4个步骤轻松修改天数!
阅读:31
-
ET文件格式和XLS格式文件之间如何转化?
阅读:24
-
react和vue的区别及优缺点是什么
阅读:121
-
支付宝人脸识别如何关闭?
阅读:21
-
腾讯微云怎么修改照片或视频备份路径?
阅读:28