加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MsSql教程 > 正文

Sqlserver2000存储过程初探

发布时间:2020-12-12 15:14:06 所属栏目:MsSql教程 来源:网络整理
导读:功能:将A表中所有符合条件的数据插入B表,且B表中某字段按某规律递增。 示例:表T_ORG_ORG(ID,UPID,DOWNID); ??????????表TEMP(ID,UPID,DOWNID); 结果:将T_ORG_ORG表中UPID=1的数据插入TEMP表,且TEMP表的ID按(X1001,X1002...,X9999)规律递增。 原理

功能:将A表中所有符合条件的数据插入B表,且B表中某字段按某规律递增。
示例:表T_ORG_ORG(ID,UPID,DOWNID);
??????????表TEMP(ID,UPID,DOWNID);
结果:将T_ORG_ORG表中UPID=1的数据插入TEMP表,且TEMP表的ID按(X1001,X1002...,X9999)规律递增。
原理:先将T_ORG_ORG表中符合条件的数据插入TEMP表,再将TEMP表中的ID按规律更新
代码:
--第一步:插入数据
insert into TEMP(ID,UPID,DOWNID) select ID,DOWNID from T_ORG_ORG where UPID=1
--第二步:更新数据
/**
*id:自增变量(int)
*currentID:游标当前值(varchar(100)与T_ORG_ORG表的ID字段对应)
*/
declare @id int,@currentID varchar(100)
set @id=1001
--id从1001开始递增
/**
*声明游标变量:mycursor
*/
declare mycursor cursor for
select ID from TEMP order by DOWNID
open mycursor

/**
*游标下移一行,并将返回值置入变量currentID
*/
fetch next from mycursor
into @currentID

/**
*while循环:条件为游标正常下移
*/

while @@FETCH_STATUS=0????
begin
/**
*更新游标当前所指记录
*/
update TEMP set ID= 'X'+cast(@id as varchar) where ID=@currentID
/**
*游标继续下移一行,并将返回值置入变量currentID
*/
fetch next from mycursor
into @currentID

/**
*自变量递增
*/
set @id=@id+1
end????--while循环结束
/**
*关闭游标,释放资源
*/
close mycursor
deallocate mycursor

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读