php 如何将循环的数据相加,MSSQL_sql中循环处理当前行数据和上一行数据相加减,  以下事例,使用游标循环 - phpStudy...

本文讲解了如何在SQL中使用游标和循环结构,通过示例演示如何在#temptable表中,以当前行的argument1累加到上一行的argument2。重点在于理解fetchnextfrom_cursor语句的位置及其在循环中的作用。
摘要由CSDN通过智能技术生成

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循环的第一行,删除第二行呢?我记得自己当时在这里出错了,呵呵。相关阅读:

Win10 Redstone最新预览版14267截图曝光

Yii CGridView用法实例详解

JS创建类和对象的两种不同方式

Win10开始菜单遭用户吐槽:动态磁贴功能不像Win8.1那样

js获取及修改网页背景色和字体色的方法

phpcms手机内容页面添加上一篇和下一篇

win10正式版更新KB3081424失败是什么原因?如何解决?

PHP Static延迟静态绑定用法分析

JavaScript中setUTCFullYear()方法的使用简介

详细说明asp.net中datareader 和 dataset 的区别

Win10 Mobile与WP8.1主题设置可以相互同步

PHP结合jQuery实现的评论顶、踩功能

PHP实现XML与数据格式进行转换类实例

mysql 加了 skip-name-resolve不能链接数据库问题的解决方法

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值