sql 行列转换

数据库中tb表格如下
月份 工资 福利 奖金
1月 100 200 300
2月 110 210 310
3月 120 220 320
4月 130 230 330

我想得到的结果是

项目 1月 2月 3月 4月
工资 100 110 120 130
福利 200 210 220 230
奖金 300 310 320 330

就是说完全把表格的行列颠倒

 

SQL code
  
  
-- SQL2005静态写法 -- 创建测试数据 create table Test(月份 varchar ( 4 ), 工资 int , 福利 int , 奖金 int ) insert Test select ' 1月 ' , 100 , 200 , 300 union all select ' 2月 ' , 110 , 210 , 310 union all select ' 3月 ' , 120 , 220 , 320 union all select ' 4月 ' , 130 , 230 , 330 go SELECT * FROM ( SELECT 考核月份,月份,金额 FROM ( SELECT 月份, 工资, 福利, 奖金 FROM Test) p UNPIVOT (金额 FOR 考核月份 IN (工资, 福利, 奖金)) AS unpvt ) T PIVOT ( MAX (金额) FOR 月份 in ( [ 1月 ] , [ 2月 ] , [ 3月 ] , [ 4月 ] )) AS pt drop table test /* 项目 1月 2月 3月 4月 -------- ------ -------- -------- -------- 奖金 300 310 320 330 工资 100 110 120 130 福利 200 210 220 230 (3 行受影响) */
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值