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 中的记录后重置标识种子
基础教程推荐
- 在多列上分布任意行 2021-01-01
- 如何在 SQL 中将 Float 转换为 Varchar 2021-01-01
- 如何根据该 XML 中的值更新 SQL 中的 XML 2021-01-01
- 什么是 orradiag_<user>文件夹? 2022-01-01
- mysql选择动态行值作为列名,另一列作为值 2021-01-01
- oracle区分大小写的原因? 2021-01-01
- MySQL 中的类型:BigInt(20) 与 Int(20) 2021-01-01
- 表 './mysql/proc' 被标记为崩溃,应该修复 2022-01-01
- 二进制文件到 SQL 数据库 Apache Camel 2021-01-01
- 在 MySQL 中:如何将表名作为存储过程和/或函数参数传递? 2021-01-01
