我从SQL Server数据库的一个表中删除了一些记录。
表中的id是这样的:
99 100 101 1200 1201...
我想删除后来的记录(ID >1200),然后我想重置自动增量,以便下一个自动生成的ID将是102。所以我的记录是顺序的,有办法做到这一点在SQL Server?
我从SQL Server数据库的一个表中删除了一些记录。
表中的id是这样的:
99 100 101 1200 1201...
我想删除后来的记录(ID >1200),然后我想重置自动增量,以便下一个自动生成的ID将是102。所以我的记录是顺序的,有办法做到这一点在SQL Server?
当前回答
我知道这是一个老问题。然而,我正在为MySQL寻找类似的解决方案,这个问题出现了。
对于那些正在寻找MySQL解决方案的人,你需要运行这个查询:
// important!!! You cannot reset the counter to a value less than or equal to the value that is currently in use. For both InnoDB and MyISAM, if the value is less than or equal to the maximum value currently in the AUTO_INCREMENT column, the value is reset to the current maximum AUTO_INCREMENT column value plus one.
ALTER TABLE <your-table-name> AUTO_INCREMENT = 100
文档
其他回答
如果你正在使用MySQL,试试这个:
ALTER TABLE tablename AUTO_INCREMENT = 1
基于已接受的答案,对于那些遇到类似问题的人,具有完整的模式限定:
([MyDataBase]。[MySchemaName]。[MyTable])……导致一个错误,您需要在该DB的上下文中
也就是说,下面的代码会抛出一个错误:
DBCC CHECKIDENT ([MyDataBase].[MySchemaName].[MyTable], RESEED, 0)
用单引号括起全限定表名:
DBCC CHECKIDENT ('[MyDataBase].[MySchemaName].[MyTable]', RESEED, 0)
重置数据库中的每个键,从最后一个最高键的最大值开始自动递增:
Exec sp_MSforeachtable 'DBCC CHECKIDENT(''?'', RESEED, 0)'
Exec sp_MSforeachtable 'DBCC CHECKIDENT(''?'', RESEED)'
DBCC CHECKIDENT('databasename.dbo.tablename', RESEED, number)
如果number = 0,那么在下一次插入时,自动递增字段将包含值1
如果number = 101,那么在下一次插入时,自动递增字段将包含值102
一些额外的信息…可能对你有用 在上述查询中给出自动递增数之前,必须确保现有表的自动递增列包含的值小于该数。
要从表(table1)中获取列(column_name)的最大值,可以使用以下查询
SELECT MAX(column_name) FROM table1
一些答案建议使用这样的语句:
DBCC CHECKIDENT (mytable, RESEED, 0)
但是OP说“删除了一些记录”,可能不是所有的记录,所以0的值并不总是正确的。另一个答案建议自动找到最大当前值并重新播种到该值,但如果表中没有记录,则会遇到麻烦,因此max()将返回NULL。一个评论建议使用简单
DBCC CHECKIDENT (mytable)
重置值,但另一个注释正确地指出,这只会将值增加到表中已经存在的最大值;如果它已经高于表中的最大值,这将不会减少该值,而这正是OP想要做的。
一个更好的解决方案结合了这些想法。第一个CHECKIDENT将值重置为0,第二个CHECKIDENT将其重置为表中当前的最大值,以防表中有记录:
DBCC CHECKIDENT (mytable, RESEED, 0)
DBCC CHECKIDENT (mytable)
正如多条注释所指出的,确保其他表中没有指向已删除记录的外键。否则,这些外键将指向您在重新播种表后创建的记录,这几乎肯定不是您想要的。