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结果如下:
私人整理,请勿直接转载。