221.标识值不连续的原因

--1. 下面的代码演示了回滚事务导致标识值不连续的情况:
--a.手工回滚事务
CREATE TABLE #(id int IDENTITY(0,1),b int)
INSERT # SELECT 1

--手工事务回滚
BEGIN TRAN
	INSERT # SELECT 2
ROLLBACK TRAN
INSERT # SELECT 2
SELECT * FROM #
DROP TABLE #
/*--结果
id           b 
----------------- ----------- 
0           1
2           2
--*/
GO

--b. 因操作失败自动回滚事务
CREATE TABLE #(id int IDENTITY(0,1),b int UNIQUE)
INSERT # SELECT 1

--违反惟一键约束,插入失败而导致自动回滚事务
INSERT # SELECT 1
INSERT # SELECT 2
SELECT * FROM #
DROP TABLE #
/*--结果
id           b 
----------------- ----------- 
0           1
2           2
--*/
GO



/*===================================================*/



--2. 删除记录导致标识值不连续
CREATE TABLE #(id int IDENTITY(0,1),b int)
INSERT # SELECT 1
INSERT # SELECT 2

--删除一条记录
DELETE # WHERE b=2
INSERT # SELECT 2
SELECT * FROM #
DROP TABLE #
/*--结果
id           b 
----------------- ----------- 
0           1
2           2
--*/
GO



/*===================================================*/



--3. 使用DBCC CHECKIDENT重置标识值导致标识值不连续的情况。
CREATE TABLE #(id int IDENTITY(0,1),b int)
INSERT # SELECT 1

--重置当前标识值
DBCC CHECKIDENT(#,RESEED,1)
INSERT # SELECT 2
select * from #
drop table #
GO
/*--结果
id           b
----------------- ----------- 
0           1
2           2
--*/
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值