`
javababy1
  • 浏览: 1166783 次
  • 性别: Icon_minigender_1
  • 来自: 北京
文章分类
社区版块
存档分类
最新评论

连续序列号中断后的处理两种处理方法

阅读更多
/**//*
*功能:中断ID的连续处理*
*适用:SQLServer2000/SQLServer2005*
*返回:NONE*
*作者:Flystone*
*日期:2008-05-13*
*/

--问题引入
/**//*
表﹕test
字段:u_nochar(2),
u_nameidchar(5)

---u_no-----------u_nameid-------
01A0001
02B8921
03F8762
.
99.....

比如我刪除了行66就是u_no為66的行,表紀錄成了:

---u_no-----------u_nameid-------
01A0001
02B8921
03F8762
.
65
67
.
99.....

我要讓u_no自己補齊刪除的數字﹐如下所示
---u_no-----------u_nameid-------
01A0001
02B8921
03F8762
.
.
.
65
66
.
98.....

*/

--环境准备



createtabletest(u_nochar(2),u_nameidchar(5))

insertintotestselect'01','A0001'unionselect
'02','B8921'unionselect
'03','F8762'unionselect
'04','C2345'unionselect
'05','C2345'unionselect
'06','C2345'unionselect
'07','C2345'unionselect
'08','C2345'unionselect
'09','C2345'
go
--方法一:触发器
createtriggertr_deleteid
ontest
fordelete
as
begin
declare@iint,@cint
select@I=min(cast(u_noasint)),@c=count(1)fromdeleted
updatetest
setu_no=right('00'+ltrim(cast(u_noasint)-@c),2)
whereu_no>@i
end
go
--原始记录
select*fromtest
/**//*

u_nou_nameid
------------
01A0001
02B8921
03F8762
04C2345
05C2345
06C2345
07C2345
08C2345
09C2345

(所影响的行数为9行)
*/

--单条删除
deletefromtestwhereu_no='02'
select*fromtest
/**//*
u_nou_nameid
------------
01A0001
02F8762
03C2345
04C2345
05C2345
06C2345
07C2345
08C2345

(所影响的行数为8行)
*/

--批量删除开始
deletefromtestwhereu_nobetween'02'and'04'
select*fromtest

/**//*

u_nou_nameid
------------
01A0001
02C2345
03C2345
04C2345
05C2345

(所影响的行数为5行)
*/


--方法二:过程处理
--
重新准备数据
droptabletest--一定要删除哦,因为上面的表有触发器哦
go

createtabletest(u_nochar(2),u_nameidchar(5))

insertintotestselect'01','A0001'unionselect
'02','B8921'unionselect
'03','C8762'unionselect
'04','D2345'unionselect
'05','E2345'unionselect
'06','F2345'unionselect
'07','G2345'unionselect
'08','H2345'unionselect
'09','I2345'
go


createprocproc_test
@u_novarchar(2),
@Lint
as
begin
declare@ichar(2)
set@i=right('00'+ltrim(cast(@u_noasint)+@L-1),2)

deletefromtestwhereu_nobetween@u_noand@i
updatetest
setu_no=right('00'+ltrim(cast(u_noasint)-@L),2)
whereu_no>@u_no
end
go

--原始记录
select*fromtest
/**//*

u_nou_nameid
------------
01A0001
02B8921
03F8762
04C2345
05C2345
06C2345
07C2345
08C2345
09C2345

(所影响的行数为9行)
*/

--单条删除
execproc_test'02',1
select*fromtest
go
/**//*

u_nou_nameid
------------
01A0001
02F8762
03C2345
04C2345
05C2345
06C2345
07C2345
08C2345

(所影响的行数为8行)
*/


--批量删除开始
execproc_test'02',2
select*fromtest
/**//*
u_nou_nameid
------------
01A0001
02E2345
03F2345
04G2345
05H2345
06I2345

(所影响的行数为6行)
*/

--清除环境
droptabletest
dropprocproc_test
分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics