sql中輪回處置以後行數據和上一行數據相加減。本站提示廣大學習愛好者:(sql中輪回處置以後行數據和上一行數據相加減)文章只能為提供參考,不一定能成為您想要的結果。以下是sql中輪回處置以後行數據和上一行數據相加減正文
以下事例,應用游標輪回表#temptable中數據,然後讓以後行和上一行中的argument1 相加 寄存到以後行的 argument2 中,比擬簡略。
--drop table #temptable create table #temptable ( argument1 int, argument2 int, argument3 datetime ) declare @rowcount int,@argument1 int,@argument2 nvarchar(50),@argument3 datetime set @rowcount=1 set @argument1=1 set @argument2=0 set @argument3=GETDATE() while(@rowcount<100) begin insert into #temptable(argument1,argument2,argument3) values(@argument1,@argument2,@argument3) set @argument1=@argument1 + datepart(day,@argument3) set @argument3=@argument3-1 set @rowcount = @rowcount + 1 end --select * from #temptable declare @lastargument2 int set @lastargument2=0 set @argument2=0 declare _cursor cursor for(select argument1 from #temptable) open _cursor; fetch next from _cursor into @argument2 while @@fetch_status = 0 begin update #temptable set argument2=@argument2+@lastargument2 where current of _cursor set @lastargument2=@argument2 fetch next from _cursor into @argument2 end close _cursor deallocate _cursor --select * from #temptable
問一個成績:
第一句fetch next from _cursor into @argument2 這句為何不克不及放在while輪回的第一行,刪除第二行呢?我記得本身其時在這裡失足了,呵呵。