oracle数据库中如何将一列的内容转换成多行
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了oracle数据库中如何将一列的内容转换成多行相关的知识,希望对你有一定的参考价值。
比如,现在有一列,列名为"检查费用",内容分别是护理费,诊断费,药费等 , 如何将此列的内容转换成要输出的表格的几个列,并且求和?
需要用wm_concat函数。
如test表中有如下数据:
现在要name列的内容都显示到同一行,可用如下语句:
查询结果:
, max(case when 检查费用 = 护理费 then 检查费用else null end)
, max(case when 检查费用 = 护理费 then 检查费用 else null end)
,sum(max(case when 检查费用 = 护理费 then 检查费用 else null end) + max(case when 检查费用 = 护理费 then 检查费用else null end)
+ max(case when 检查费用 = 护理费 then 检查费用 else null end))
from table 参考技术B 1、需要确保各种费用之间是有分隔符的,比如逗号
2、因为要做求和,因此需要确保费用值是数值类型的
3、每行数据的费用种类的数量是否一致?
在确认了上面的问题后,可以编写一个自定义函数来实现 参考技术C select 病人,
sum(decode(检查费用,'护理费', 护理金额,0) as 护理费 ,
sum(decode(检查费用,'诊断费', 诊断费金额,0) as 诊断费 ,
.............
from biao group by 病人本回答被提问者采纳 参考技术D 总得有个条件判断是什么费用才行哦。。你是从哪里判断出事护理费,诊断费的。。。补充问题说清楚,要不神仙也帮不了你啊。。我关注着。。
比如从别的列进行判断 是哪个部门 出示的检查费用。。
或者 检查费用 这个列 是VARCHAT2型的,"222.00(护理费用)"。。
如何将Oracle中同一列的多行记录拼接成一个字符串
1、新建php文件。
2、声明数组变量。
3、用implode函数使数组拼接成字符串,连接符为-。
4、输出连接后的字符串。
5、预览效果如图。
6、用implode函数使数组拼接成字符串,连接符为?。
7、预览效果如图。
参考技术A需要用wm_concat函数来实现。
如目前在emp表中查询数据如下:
要按照deptno相同的将ename以字符串形式合并,可用如下语句:
查询结果:
select 'China' nation ,'Guangzhou' city from dual union all
select 'China' nation ,'Shanghai' city from dual union all
select 'China' nation ,'Beijing' city from dual union all
select 'USA' nation ,'New York' city from dual union all
select 'USA' nation ,'Bostom' city from dual union all
select 'Japan' nation ,'Tokyo' city from dual
)
SELECT nation,listagg(city) within GROUP(ORDER BY city)
FROM temp
Group BY Nation; 参考技术D 使用CURSOR循环拼接即可!
以上是关于oracle数据库中如何将一列的内容转换成多行的主要内容,如果未能解决你的问题,请参考以下文章
关于SQL Server将一列的多行内容拼接成一行的问题讨论
关于SQL Server将一列的多行内容拼接成一行的问题讨论