您现在的位置是:网站首页> 编程资料编程资料
sql中循环处理当前行数据和上一行数据相加减_MsSql_
2023-05-26
536人已围观
简介 sql中循环处理当前行数据和上一行数据相加减_MsSql_
以下事例,使用游标循环表#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循环的第一行,删除第二行呢?我记得自己当时在这里出错了,呵呵。
您可能感兴趣的文章:
相关内容
- SQL SERVER先判断视图是否存在然后再创建视图的语句_MsSql_
- SQL语句中含有乘号报错的处理办法_MsSql_
- Transactional replication(事务复制)详解之如何跳过一个事务_MsSql_
- SQL SERVER中关于exists 和 in的简单分析_MsSql_
- MSSQL段落还原脚本,SQLSERVER段落脚本_MsSql_
- 浅析SQL server 临时表_MsSql_
- SQLSERVER 清除历史记录的方法_MsSql_
- SQLServer恢复表级数据详解_MsSql_
- 一个函数解决SQLServer中bigint 转 int带符号时报错问题_MsSql_
- sql中循环处理当前行数据和上一行数据相加减_MsSql_
