Oralce数据库

本文介绍了如何使用Oracle SQL通过GROUP BY和CASE语句将同一个人的不同费用(学费、住宿费、书本费)信息整合为一条数据记录,展示了具体的SQL查询语句和执行结果,适用于数据聚合场景。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Oralce如何将多数据转为一条数据实例

公司要求:将下面的文本信息转为一条数据,该图中内容为测试数据,请供参考
要处理的数据
现在要将三条同一个人的学费、住宿费、书本费转为一条数据。

select 
t.uni_no,max(t.name) NAME,max(t.termyear) termyear ,
MAX(CASE t.Fcode when '101' THEN t.FCODE else null end ) FCODE1,
MAX(CASE t.Fcode when '101' THEN t.Fname else null end ) FNAME1,
MAX(CASE t.Fcode when '101' THEN t.SAMT else null end ) SAMT1,
MAX(CASE t.Fcode when '101' THEN t.YAMT else null end ) YAMT1,
MAX(CASE t.Fcode when '201' THEN t.FCODE else null end ) FCODE2,
MAX(CASE t.Fcode when '201' THEN t.Fname else null end ) FNAME2,
MAX(CASE t.Fcode when '101' THEN t.SAMT else null end ) SAMT2,
MAX(CASE t.Fcode when '101' THEN t.YAMT else null end ) YAMT2,
MAX(CASE t.Fcode when '301' THEN t.FCODE else null end ) FCODE3,
MAX(CASE t.Fcode when '301' THEN t.Fname else null end ) FNAME3,
MAX(CASE t.Fcode when '101' THEN t.SAMT else null end ) SAMT3,
MAX(CASE t.Fcode when '101' THEN t.YAMT else null end ) YAMT3
from ft_xsjfxx_to_jzxg_zhent  t  where uni_no='1802343334' group by  t.uni_no

group by 方法支持单条不同数据,如果存在相同数据,列如 姓名 (NAME) 处理的方法 MAX()函数即可。
对应sql结果如下:
结果

私人整理,请勿直接转载。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值