Oralce数据库

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结果如下:
结果

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

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值