微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

Sqlserver2000存储过程初探

功能:将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

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐