作为标题,我有一个已经填充了150000条记录的现有表。我添加了一个Id列(目前为空)。

我假设我可以运行一个查询,用增量数字填充这个列,然后设置为主键并打开自动增量。这是正确的做法吗?如果是,我怎么填入初始数字?


当前回答

如果这个列在你的表中已经存在,并且它是空的,你可以用这个命令更新这个列(替换id, tablename和tablekey):

UPDATE x
SET x.<Id> = x.New_Id
FROM (
  SELECT <Id>, ROW_NUMBER() OVER (ORDER BY <tablekey>) AS New_Id
  FROM <tablename>
  ) x

其他回答

这里有一个你可以尝试的主意。 原始表-没有标识列table1 创建一个新的表-调用表2和标识列。 将数据从table1复制到table2 -标识列自动填充自动递增的数字。

将原表table1重命名为table3 将新表- table2重命名为table1(原始表) 现在已经有了包含标识列的表1,并为现有数据填充了标识列。 在确保没有问题并且工作正常后,在不再需要时删除表3。

修改表table_name,增加列ID 这可能很有用

试试下面的代码:

DBCC CHECKIDENT ('settings', RESEED, 0) 

不-你必须以另一种方式来做:从一开始就添加它为INT IDENTITY -当你这样做时,它将被标识值填充:

ALTER TABLE dbo.YourTable
   ADD ID INT IDENTITY

然后你可以让它成为主键

ALTER TABLE dbo.YourTable
   ADD CONSTRAINT PK_YourTable
   PRIMARY KEY(ID)

或者如果你更喜欢一步完成:

ALTER TABLE dbo.YourTable
   ADD ID INT IDENTITY
       CONSTRAINT PK_YourTable PRIMARY KEY CLUSTERED
ALTER TABLE table_name ADD temp_col INT IDENTITY(1,1) 
update