1
2
3
4
删除一个 4
在插入的时候
默认是
type
1
2
3
5
请问什么怎么让他重置?或者有其他的办法,我用的是DBCC CHECKIDENT 但是好像重置的语句不管用
我想要的是新插入后是
type
1
2
3
4
3 个解决方案
#1
create table tb(id int identity(1,1),c2 varchar(10))
insert into tb(c2) select 'abc'
union all select 'def'
union all select 'hij'
union all select 'klm'
union all select 'xyz'
go
delete from tb where id=4
select * from tb
/*
id c2
----------- ----------
1 abc
2 def
3 hij
5 xyz
(4 行受影响)
*/
go
--下面开始处理
select * into # from tb
truncate table tb
insert into tb(c2)
select c2 from # order by id
select * from tb
/*
id c2
----------- ----------
1 abc
2 def
3 hij
4 xyz
(4 行受影响)
*/
go
drop table tb
#2
......可以有不删除表的么。。。这个动作太大了
#3
DBCC CHECKIDENT (table name, RESEED, itentity value)
--reset the identity values
肯定管用,我试过的,不过你要先找出断层的值然后再重设。
--reset the identity values
肯定管用,我试过的,不过你要先找出断层的值然后再重设。
#1
create table tb(id int identity(1,1),c2 varchar(10))
insert into tb(c2) select 'abc'
union all select 'def'
union all select 'hij'
union all select 'klm'
union all select 'xyz'
go
delete from tb where id=4
select * from tb
/*
id c2
----------- ----------
1 abc
2 def
3 hij
5 xyz
(4 行受影响)
*/
go
--下面开始处理
select * into # from tb
truncate table tb
insert into tb(c2)
select c2 from # order by id
select * from tb
/*
id c2
----------- ----------
1 abc
2 def
3 hij
4 xyz
(4 行受影响)
*/
go
drop table tb
#2
......可以有不删除表的么。。。这个动作太大了
#3
DBCC CHECKIDENT (table name, RESEED, itentity value)
--reset the identity values
肯定管用,我试过的,不过你要先找出断层的值然后再重设。
--reset the identity values
肯定管用,我试过的,不过你要先找出断层的值然后再重设。