今天接到业务部门的一个需求,需要对同一公司的不同财务指标进行排序,需要用到oracle的行转列函数unpivot。

财务报表的表结构为:

要实现业务部门的排序筛选功能,需要首先将行数据转为列数据:

使用unpivot函数,实现如下

with t4 as (select t3.COMPCODE,
t3.ENDDATE,
t3.CURFDS as "货币资金",
t3.TRADFINASSET as "交易性金融资产",
t3.NOTESRECE as "应收票据",
t3.PLAC AS "拆出资金",
T3.DERIFINAASSET AS "衍生金融资产",
T3.ACCORECE AS "应收账款",
T3.PREP AS "预付款项",
T3. PREMRECE AS "应收保费",
T3. REINRECE AS "应收分保账款",
T3. REINCONTRESE AS "应收分保合同准备金",
T3. INTERECE AS "应收利息",
T3. DIVIDRECE AS "应收股利",
T3. OTHERRECE AS "其他应收款",
T3. EXPOTAXREBARECE AS "应收出口退税",
T3. SUBSRECE AS "应收补贴款",
T3. MARGRECE AS "应收保证金",
T3. INTELRECE AS "内部应收款",
T3. PURCRESAASSET AS "买入返售金融资产",
T3. INVE AS "存货",
T3. ACCHELDFORS AS "划分为持有待售的资产",
T3. PREPEXPE AS "待摊费用",
T3. UNSEG AS "待处理流动资产损益",
T3. EXPINONCURRASSET AS "一年内到期的非流动资产",
T3. OTHERCURRASSE AS "其他流动资产",
T3. TOTCURRASSET AS "流动资产合计",
T3. LENDANDLOAN AS "发放贷款及垫款",
T3. AVAISELLASSE AS "可供出售金融资产",
T3. HOLDINVEDUE AS "持有至到期投资",
T3. LONGRECE AS "长期应收款",
T3. EQUIINVE AS "长期股权投资",
T3. OTHERLONGINVE AS "其他长期投资",
T3. INVEPROP AS "投资性房地产",
T3. FIXEDASSEIMMO AS "固定资产原值",
T3. ACCUDEPR AS "累计折旧",
T3. FIXEDASSENETW AS "固定资产净值",
T3. FIXEDASSEIMPA AS "固定资产减值准备",
T3. FIXEDASSENET AS "固定资产净额",
T3. CONSPROG AS "在建工程",
T3. ENGIMATE AS "工程物资",
T3. FIXEDASSECLEA AS "固定资产清理",
T3. PRODASSE AS "生产性生物资产",
T3. COMASSE AS "公益性生物资产",
T3. HYDRASSET AS "油气资产",
T3. INTAASSET AS "无形资产",
T3. DEVEEXPE AS "开发支出",
T3. GOODWILL AS "商誉",
T3. LOGPREPEXPE AS "长期待摊费用",
T3. TRADSHARTRAD AS "股权分置流通权",
T3. DEFETAXASSET AS "递延所得税资产",
T3. OTHERNONCASSE AS "其他非流动资产"
from TQ_FIN_PROBALSHEETNEW t3)
select COMPCODE , ENDDATE, zhibiao, jine from t4 unpivot (jine for zhibiao in ("应收保费",
"应收分保账款",
"应收分保合同准备金",
"应收利息",
"应收股利",
"其他应收款",
"应收出口退税",
"应收补贴款",
"应收保证金",
"内部应收款",
"买入返售金融资产",
"存货",
"划分为持有待售的资产",
"待摊费用",
"待处理流动资产损益",
"一年内到期的非流动资产",
"其他流动资产",
"流动资产合计",
"发放贷款及垫款",
"可供出售金融资产",
"持有至到期投资" ,
"长期应收款" ,
"长期股权投资" ,
"其他长期投资" ,
"投资性房地产" ,
"固定资产原值" ,
"累计折旧" ,
"固定资产净值" ,
"固定资产减值准备",
"固定资产净额" ,
"在建工程" ,
"工程物资" ,
"固定资产清理" ,
"生产性生物资产" ,
"公益性生物资产" ,
"油气资产" ,
"无形资产" ,
"开发支出" ,
"商誉" ,
"长期待摊费用" ,
"股权分置流通权" ,
"递延所得税资产" ,
"其他非流动资产"
) )

  

oracle 行转列函数pivot和unpivot的更多相关文章

  1. Oracle行转列,pivot函数和unpivot函数

    pivot函数:行转列函数: 语法:pivot(任一聚合函数 for 需专列的值所在列名 in (需转为列名的值)):unpivot函数:列转行函数: 语法:unpivot(新增值所在列的列名 for ...

  2. oracle行转列函数WMSYS.WM_CONCAT 用法

    1.通过 10g 所提供的 WMSYS.WM_CONCAT 函数即可以完成 行转列的效果 select group_code, wm_concat(display_title) from DR_OPM ...

  3. oracle行转列函数以及一些窗口函数(PIVOT ,OVER)

    可以查看博客园上传的文件 pivot  除了要转成列的字段(classnum,classid)值不一样,其他值都应该相同,否则转的数据有问题

  4. 使用SQL行转列函数pivot遇到的问题

    背景:对投票的结果按照单位进行汇总统计,数据库中表记录的各个账号对各个选项的投票记录.马上想到一个解决方案,先根据单位和选项进行Group By,然后再行转列得出单位对各个选项的投票情况. with ...

  5. oracle行转列函数

  6. [转]Oracle SQL函数pivot、unpivot转置函数实现行转列、列转行

    原文地址:http://blog.csdn.net/seandba/article/details/72730657 函数PIVOT.UNPIVOT转置函数实现行转列.列转行,效果如下图所示: 1.P ...

  7. Oracle 行转列pivot 、列转行unpivot 的Sql语句总结

    这个比较简单,用||或concat函数可以实现 select concat(id,username) str from app_user select id||username str from ap ...

  8. Oracle 行转列 动态出转换的列

    本文链接:https://blog.csdn.net/Huay_Li/article/details/82924443 10月的第二天,前天写了个Oracle中行转列的pivot的基本使用方法,然后, ...

  9. Oracle 行转列(不固定行数的行转列,动态)(转)

    http://bbs.csdn.net/topics/330039676 SQLSERVER :行列转换例子:  http://www.cnblogs.com/gaizai/p/3753296.htm ...

随机推荐

  1. 分金币 (UVA 11300)

    http://acm.hust.edu.cn/vjudge/problem/viewProblem.action?id=33899 思路:推公式,发现可以转化为求给定n个数,求到所有点距离之和最小的点 ...

  2. HDU - 6446 Tree and Permutation

    传送门:http://acm.hdu.edu.cn/showproblem.php?pid=6446 本题是一个树上的问题——DFS. 一棵N个结点的树,其结点为1~N.树具有N-1条边,每一条边具有 ...

  3. MessageFormat理解,MessageFormat.format(Object obj)方法

    MessageFormat.format(Object obj)方法主要用途为拼接message信息 用法: Object[] testArgs = {new String("张三" ...

  4. Linux下汇编语言学习笔记73 ---

    这是17年暑假学习Linux汇编语言的笔记记录,参考书目为清华大学出版社 Jeff Duntemann著 梁晓辉译<汇编语言基于Linux环境>的书,喜欢看原版书的同学可以看<Ass ...

  5. Ubuntu 16.04安装VLC播放器,替代系统默认播放器

    VLC播放器应该说是开源项目中最好的视频播放器,但功能不止于视频播放,还有视频直播等等.可以通过安装字幕插件搜索字母等. 安装步骤: 1.安装: sudo add-apt-repository ppa ...

  6. Git flow的分支模型与及经常使用命令简单介绍

    Git flow是git的一个扩展集,它基于Vincent Driessen 的分支模型,文章"A successful Git branching model"对这一分支模型进行 ...

  7. android微信开放平台,申请移动应用的应用签名怎样获取

    在微信开放平台,申请移动应用的时候: https://open.weixin.qq.com/cgi-bin/appcreate? t=manage/createMobile&type=app& ...

  8. Codeforces 91C Ski Base 加边求欧拉回路数量

    题目链接:点击打开链接 题意: 给出n个点m条无向边的图 開始图里没有边.每次加一条边,然后输出图里欧拉回路的条数. 思路: We will count the number of ski bases ...

  9. LeetCode 141. Linked List Cycle (链表循环)

    Given a linked list, determine if it has a cycle in it. Follow up:Can you solve it without using ext ...

  10. Android离线语音识别(PocketSphinx)

    近期做项目.用到离线语音识别.整了好久,查了好多方法.最终完毕.网上资料有点乱,并且大部分就是那几个人写的.一群人转!以下我总结一下.也为后来人行个方便. 关于环境配置我就不多说了.我就是依照这个教程 ...