同一个表中今天的数据与昨天的数据合并,并制定列

列:RecYear(int),RecMonth(int),RecDay(int),T0000,T0010,T0020,T0030,T0040..

将2012-5-12的数据与2012-5-11的数据组合


declare @sql as nvarchar(max)
declare @selectstr as nvarchar(max)
set @selectstr = 'a.RecYear,a.RecMonth,a.RecDay,'
declare @i as int
set @i=0
while @i<=50
begin
--print right('0000'+cast(@i as nvarchar(4)),4)
set @selectstr = @selectstr + 'a.T'+right('0000'+cast(@i as nvarchar(4)),4) + ','
set @i=@i+10
end

set @i=60
while @i<=90
begin
--print right('0000'+cast(@i as nvarchar(4)),4)
set @selectstr = @selectstr + 'b.T'+right('0000'+cast(@i as nvarchar(4)),4) + ','
set @i=@i+10
end
set @selectstr = left(@selectstr,len(@selectstr)-1)
set @sql = 'select ' + @selectstr + ' from License
a left join License b
on dbo.toDate(a.RecYear,a.RecMonth,a.RecDay)=DateAdd(dd,1,dbo.toDate(b.RecYear,b.RecMonth,b.RecDay))
'
exec(@sql)

 

 

create function toDate(@year int,@month int,@day int)
returns datetime
as
begin
return(select cast(cast(@year as varchar) +'-'+ cast(@month as varchar) +'-'+ cast(@day as varchar) as datetime))
end

转载于:https://www.cnblogs.com/blackbean/archive/2012/05/16/2504364.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值