大家好。我的数据库中有一个表,其中包含约一千条记录。我想重置标识列,以便所有ID都再次按顺序进行。我当时在看this,但我假设它只能在空表上使用
当前表
ID | Name
1 Joe
2 Phil
5 Jan
88 Rob
所需表
ID | Name
1 Joe
2 Phil
3 Jan
4 Rob
提前致谢
最佳答案
最简单的方法是制作当前表的副本,解决所有父代问题,将其删除,然后重命名新表。
您也可以暂时删除IDENTITY
并尝试以下操作:
;WITH TBL AS
(
SELECT *, ROW_NUMBER(ORDER BY ID) AS RN
FROM CURRENT_TABLE
)
UPDATE TBL
SET ID = RN
或者,如果您不在乎记录的顺序,则此
DECLARE INT @id;
SET @id = 0;
UPDATE CURRENT_TABLE
SET @id = ID = @id + 1;