Sqlserver2000存储过程初探

Sqlserver2000存储过程初探,第1张

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

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

总结

以上是内存溢出为你收集整理的Sqlserver2000存储过程初探全部内容,希望文章能够帮你解决Sqlserver2000存储过程初探所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/1182537.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-02
下一篇 2022-06-02

发表评论

登录后才能评论

评论列表(0条)

保存