博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
逐月对比的交叉表处理
阅读量:4190 次
发布时间:2019-05-26

本文共 1496 字,大约阅读时间需要 4 分钟。

/*--原帖地址:

--*/

--测试数据

create table tb(year int,month int,No varchar(10),Name varchar(10),部门 varchar(10),工资 int)
insert tb select 2004,10,'A001','AAA','DDD',1000
union all select 2004,10,'B001','BBB','DDD',800
union all select 2004,11,'A001','AAA','DDD',1100
union all select 2004,11,'B001','BBB','DDD',1000
union all select 2004,12,'A001','AAA','DDD',1200
union all select 2004,12,'B001','BBB','DDD',1050

/*--处理要求

 将月份做为字段,并且反应逐月的工资增幅,例如上面的数据要求结果如下,注意最小的年月是没有增幅的

No     Name   部门   2004_10   2004_11  2004_11增幅  2004_12  2004_12增幅 

------ ------ ------ --------- -------- ----------- --------- ------------
A001   AAA    DDD    1000      1100     10.00%      1200      9.09%
B001   BBB    DDD    800       1000     25.00%      1050      5.00%
--*/

go

--查询处理

declare @s nvarchar(4000),@i int
select @s='',@i=0
select @s=@s+','+quotename(fd)
  +'=sum(case when a.year='+year
  +' and a.month='+month
  +' then a.工资 end)'
 +case @i when 0 then ''
  else ','+quotename(fd+'增幅')
   +'=cast(cast(sum(case when a.year='+year
   +' and a.month='+month
   +' then a.工资-b.工资 end)*100.'
   +'/sum(case when a.year='+year
   +' and a.month='+month
   +' then b.工资 end)'
   +' as decimal(10,2)) as varchar)+''%'''
 end,@i=@i+1
from(
 select year=rtrim(year),month=rtrim(month),
  fd=rtrim(year)+'_'+rtrim(month)
 from tb group by year,month)a
exec('select a.No,a.Name,a.部门
from tb a
 left join tb b on a.No=b.No and a.Name=b.Name and a.部门=b.部门
  and a.year=b.year+(b.month)/12
  and a.month=b.month%12+1
 group by a.No,a.Name,a.部门')
go

--删除测试

drop table tb

Trackback: http://tb.blog.csdn.net/TrackBack.aspx?PostId=320638

你可能感兴趣的文章
奏响春的序曲,「武汉的春天」让人泪目
查看>>
华大基因:新型冠状病毒检测试剂盒日均产能已达8万人份
查看>>
情人节集体撤档,《肥龙过江》改网播,线上首映会成为常态吗?
查看>>
富士康工业互联:生产口罩优先用于内部防疫 预计对经营业绩影响较小
查看>>
横店影视:旗下影院1月24日起全部暂停营业 手握11.2亿元理财产品现金流充足...
查看>>
华为P40 Pro相机高清细节图曝光:潜望式长焦镜头抢眼
查看>>
“抢菜大战”背后:生鲜电商的突击大考
查看>>
巴菲特:马斯克是伟大企业家,但特斯拉股票不是好投资标的
查看>>
骁龙865+65W闪充!realme 真我X50 Pro 5G正式全球发布
查看>>
二月手机好评排行榜公布:华为第一,小米10没上榜
查看>>
英特尔展示业界首个一体封装光学以太网交换机
查看>>
年存10W+的年轻人都是怎么攒钱的
查看>>
苹果确认部分iPad Air 3会出现永久性黑屏:可免费维修
查看>>
iPhone 11全球供应紧张:何时补货未知
查看>>
小米40W无线闪充今年商用:MIX 4首发?
查看>>
国产手机卖的越来越贵,是好是坏?
查看>>
拼多多联合三奇医卫等企业,每天上架1000万只平价口罩
查看>>
5000起步没商量!vivo NEX 3S 5G手机正式发布:骁龙865+无界瀑布屏加持
查看>>
二月1500-1999元性价比排行榜:前三都是魅族手机
查看>>
疫情下的“双11”,品牌逆势增长背后的数字化变革
查看>>