壹佰网|ERP100 - 企业信息化知识门户

 找回密码
 注册

QQ登录

只需一步,快速开始

查看: 3362|回复: 7

将竖的数据转化为横的

[复制链接]
发表于 2007/5/17 15:28:11 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。如果您注册时有任何问题请联系客服QQ: 83569622  。

您需要 登录 才可以下载或查看,没有帐号?注册

x
Hi,

    请教各位有没有好的方法,比较急,谢谢各位!

原来数据显示格式如下:
部门        季度  收入1             收入2
Others      1 21200079.5321243 20983805.6121243
Others      2 889838.547008547 889838.547008547
China1  1 33466438.2299045 29414497.0099045
China2  1 10670801.025875 1 0137784.765875

想转成
部门                       季度1                     季度2
                    收入1      收入2              收入1      收入2
Others      21200079.5321243 20983805.6121243
Others                                          889838.547008547 889838.547008547
China1 33466438.2299045 29414497.0099045
China2  10670801.025875 1 0137784.765875
发表于 2007/5/17 16:17:04 | 显示全部楼层
select 部门,sum(decode(季度,'1'
                                  ,收入1)) "季度1 收入1"
               ,sum(decode(季度,'1'
                                  ,收入2)) "季度1 收入2"
               ,sum(decode(季度,'2'
                                  ,收入1)) "季度2 收入1"
               ,sum(decode(季度,'2'
                                  ,收入2)) "季度2 收入2"
from <your table or view>
group by 部门

评分

参与人数 1壹佰币 +1 收起 理由
jiawu8000 + 1 支持支持(^0^)

查看全部评分

发表于 2007/5/17 18:32:19 | 显示全部楼层
上面的方法,decode 的函數就是具有這樣的功能!
发表于 2007/5/18 08:07:31 | 显示全部楼层
导出到EXCEL
复制,选择性粘贴,倒置,确定
哈哈
 楼主| 发表于 2007/5/18 10:05:35 | 显示全部楼层
用bhbb2000 (Phoenix)

幼稚园学生
的方法可以实现
现在还需用在后面加年度的统计
部门                   季度1                     季度2                                 YTD                             
             收入1      收入2              收入1      收入2                    收入1   收入2
Others      21200079.5321243 20983805.6121243
Others                                          889838.547008547 889838.547008547
China1 33466438.2299045 29414497.0099045
China2  10670801.025875 1 0137784.765875

请问如何再1楼的基础上加SQL 谢谢!
发表于 2007/5/18 10:52:46 | 显示全部楼层
原帖由 ostone 于 2007-5-18 10:05 发表
用bhbb2000 (Phoenix)

幼稚园学生
的方法可以实现
现在还需用在后面加年度的统计
部门                   季度1                     季度2                                 YTD                    ...


已经写到这里,你应该可以类推出来,有“年”这一列吗?,如果没有,你可以这样加一列:

sum(decode(季度,'1',收入1+收入2
                           ,'2',收入1+收入2
                           ,'3',收入1+收入2
                           ,'4',收入1+收入2)) YTD
发表于 2007/5/19 22:49:10 | 显示全部楼层
如果数据大的话
建议搞到临时表进行处理
这样一般不会出错 呵呵
 楼主| 发表于 2009/12/9 15:50:07 | 显示全部楼层
还有一种方法 用case
sum(case piv.input_value_id when 145447 then par.result_value end)  实发午餐补贴,
       sum(case piv.input_value_id when 145442 then par.result_value end)  实发综合补贴,
       sum(case piv.input_value_id when 145432 then par.result_value end)  实发岗位工资,
您需要登录后才可以回帖 登录 | 注册

本版积分规则

QQ|Archiver|小黑屋|手机版|壹佰网 ERP100 ( 京ICP备19053597号-2 )

Copyright © 2005-2012 北京海之大网络技术有限责任公司 服务器托管由互联互通
手机:13911575376
网站技术点击发送消息给对方83569622   广告&合作 点击发送消息给对方27675401   点击发送消息给对方634043306   咨询及人才点击发送消息给对方138011526

GMT+8, 2025/11/29 00:36 , Processed in 0.014622 second(s), 15 queries , File On.

Powered by Discuz! X3.4

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表