删除 SQL Server 中的记录后重置标识种子

Reset identity seed after deleting records in SQL Server(删除 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 中的记录后重置标识种子的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!

本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!

相关文档推荐

Execute complex raw SQL query in EF6(在EF6中执行复杂的原始SQL查询)
Hibernate reactive No Vert.x context active in aws rds(AWS RDS中的休眠反应性非Vert.x上下文处于活动状态)
Bulk insert with mysql2 and NodeJs throws 500(使用mysql2和NodeJS的大容量插入抛出500)
Flask + PyMySQL giving error no attribute #39;settimeout#39;(FlASK+PyMySQL给出错误,没有属性#39;setTimeout#39;)
auto_increment column for a group of rows?(一组行的AUTO_INCREMENT列?)
Sort by ID DESC(按ID代码排序)