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,UPID,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

你可能感兴趣的:(sqlserver2000)