`
- 浏览:
1166783 次
- 性别:
- 来自:
北京
-
/**//*
*功能:中断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
相关推荐
总结两种方法,java获取硬盘序列号的两种方法
MasterCAM后处理换刀前一行输出序列号N代码视频教程
模拟硬盘物理序列号模拟硬盘物理序列号模拟硬盘物理序列号模拟硬盘物理序列号模拟硬盘物理序列号模拟硬盘物理序列号模拟硬盘物理序列号模拟硬盘物理序列号模拟硬盘物理序列号模拟硬盘物理序列号模拟硬盘物理序列号...
Everest序列号
获取硬盘序列号的方法很多种,但是大多不是很通用,获取序列号成功率不高,本资源的方法经过了不同机型的大量测试均能正确获取硬盘序列号
一般情况下,序列号都是厂商自己定义的一串字串,字串中的某几位会有不同含义,比如厂商的ID、出厂时间、机器类型等,另外,运营商定义的序列号几乎也是遵循这样的规律。 出厂时序列号的烧录 这个是烧录程序做的事情。...
卡巴序列号卡吧序列号卡吧序列号卡吧序列号卡吧序列号卡吧序列号卡吧序列号卡吧序列号卡吧序列号卡吧序列号卡吧序列号卡吧序列号卡吧序列号卡吧序列号卡吧序列号卡吧序列号卡吧序列号
2.使用说明:打开程序后,点按钮后,三个TEXTBOX分别显示全球唯一标识的硬盘物理序列号、WMI方法获取的硬盘序列号、WMI方法获取的CPU序列号 3.WMI方法被很多人诟病,有说读不出来什么的,我测试了几台机器确实有读不...
底层函数获取windows磁盘序列号 mac地址。 硬盘序列号,英文名:Hard Disk Serial Number,该号是硬盘厂家为区别产品而设置的,...硬盘格式化后,这种序列号将发生变化。本文描述的是获取硬盘唯一的物理序列号的方法。
C#4种方式获取硬盘物理序列号,不同方式针对不同环境下获取,windows7,8,10,2003,2008,2012,2016都测试可用
由于保密要做计算机台账,需要登记很多电脑信息,很麻烦,我自己写了一个电脑基本信息查看器,包括操作系统类型(xp~win10),系统...所有采用5种方式获取序列号,总有一个方法能获取到,获取失败请使用管理员身份运行。
是c语言做的一个简单的注册机,可以获取cpu序列号,硬盘序列号等信息,通过md5加密生成注册码,可以参考制作注册机
VB6编写的,读取硬盘物理序列号/逻辑序列号/CPU序列号/主板序列号 一个界面,集成了上述序列号的读取,源代码均来自于网上,我集成在一起,调试通过.
MyEclipse序列号 大家不要下,因为本人上班外网有限制,所以只能用CSDN了。
通过 WMI 或 API 方法读取U盘序列号
使QuickTime Player 7 成为Pro版的方法以及序列号,以及解决注册成Pro版后CPU占用100%的解决方法。
先将网上搜到的[Nero 8 Ultra Edition HD]版本的序列号4K2K-0027-1105-E955-50MM-7E14-K180更换掉原先的序列号[1K22-0867-0795-66M4-5025-3395-3429],更换方法如下:在“运行”里输入“regedit”,依次打开“HKEY_...
【源码】VB6.0获取硬盘序列号、获取硬盘逻辑盘序列号、获取CPU序列号、获取主板序列号
MyEclipse6.0自动生成序列号的方法,太简单强大了 Myeclipse序列号 使用方法:运行里面的这段小代码,然后输入一个用户名,就会自动打印出对应此用户名的序列号
vb6.0序列号 vb6.0序列号 vb6.0序列号 vb6.0序列号 vb6.0序列号 vb6.0序列号 vb6.0序列号