Reset identity seed after deleting records in SQL Server(删除 SQL Server 中的记录后重置标识种子)
问题描述
我已将记录插入到 SQL Server 数据库表中.该表定义了一个主键,并且自动递增标识种子设置为是".这样做主要是因为在 SQL Azure 中,每个表都必须定义一个主键和标识.
I have inserted records into a SQL Server database table. The table had a primary key defined and the auto increment identity seed is set to "Yes". This is done primarily because in SQL Azure, each table has to have a primary key and identity defined.
但由于我必须从表中删除一些记录,这些表的身份种子将受到干扰,索引列(自动生成的增量为 1)将受到干扰.
But since I have to delete some records from the table, the identity seed for those tables will be disturbed and the index column (which is auto-generated with an increment of 1) will get disturbed.
如何在删除记录后重新设置标识列,使该列按数字升序排列?
身份列不用作数据库中任何地方的外键.
The identity column is not used as a foreign key anywhere in database.
推荐答案
DBCC CHECKIDENT
管理命令用于重置身份计数器.命令语法为:
The DBCC CHECKIDENT
management command is used to reset identity counter. The command syntax is:
DBCC CHECKIDENT (table_name [, { NORESEED | { RESEED [, new_reseed_value ]}}])
[ WITH NO_INFOMSGS ]
示例:
DBCC CHECKIDENT ('[TestTable]', RESEED, 0);
GO
以前版本的 Azure SQL 数据库不支持,但现在支持.
It was not supported in previous versions of the Azure SQL Database but is supported now.
感谢 所罗门Rutzky docs 现在已修复.
Thanks to Solomon Rutzky the docs for the command are now fixed.
这篇关于删除 SQL Server 中的记录后重置标识种子的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:删除 SQL Server 中的记录后重置标识种子


基础教程推荐
- SQL Server 中单行 MERGE/upsert 的语法 2021-01-01
- SQL Server:只有 GROUP BY 中的最后一个条目 2021-01-01
- 将数据从 MS SQL 迁移到 PostgreSQL? 2022-01-01
- 无法在 ubuntu 中启动 mysql 服务器 2021-01-01
- ERROR 2006 (HY000): MySQL 服务器已经消失 2021-01-01
- Sql Server 字符串到日期的转换 2021-01-01
- 使用pyodbc“不安全"的Python多处理和数据库访问? 2022-01-01
- SQL Server 2016更改对象所有者 2022-01-01
- 在 VB.NET 中更新 SQL Server DateTime 列 2021-01-01
- 如何在 SQL Server 的嵌套过程中处理事务? 2021-01-01