各位用户为了找寻关于sql中循环处理当前行数据和上一行数据相加减的资料费劲了很多周折。这里教程网为您整理了关于sql中循环处理当前行数据和上一行数据相加减的相关资料,仅供查阅,以下为您介绍关于sql中循环处理当前行数据和上一行数据相加减的详细内容
以下事例,使用游标循环表#temptable中数据,然后让当前行和上一行中的argument1 相加 存放到当前行的 argument2 中,比较简单。
? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45--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循环的第一行,删除第二行呢?我记得自己当时在这里出错了,呵呵。