作为标题,我有一个已经填充了150000条记录的现有表。我添加了一个Id列(目前为空)。
我假设我可以运行一个查询,用增量数字填充这个列,然后设置为主键并打开自动增量。这是正确的做法吗?如果是,我怎么填入初始数字?
作为标题,我有一个已经填充了150000条记录的现有表。我添加了一个Id列(目前为空)。
我假设我可以运行一个查询,用增量数字填充这个列,然后设置为主键并打开自动增量。这是正确的做法吗?如果是,我怎么填入初始数字?
当前回答
试着这样做(先在测试台上):
USE your_database_name GO WHILE (SELECT COUNT(*) FROM your_table WHERE your_id_field IS NULL) > 0 BEGIN SET ROWCOUNT 1 UPDATE your_table SET your_id_field = MAX(your_id_field)+1 END PRINT 'ALL DONE'
我根本没有测试过这个,所以要小心!
其他回答
ALTER TABLE table_name ADD temp_col INT IDENTITY(1,1)
update
这个答案是对投票最多的答案的一个小补充,适用于SQL Server。问题要求自动增加主键,当前答案确实添加了主键,但它没有被标记为自动增加。下面的脚本检查列是否存在,并在启用自动递增标志的情况下添加它。
IF NOT EXISTS (SELECT * FROM INFORMATION_SCHEMA.COLUMNS
WHERE TABLE_NAME = 'YourTable' AND COLUMN_NAME = 'PKColumnName')
BEGIN
ALTER TABLE dbo.YourTable
ADD PKColumnName INT IDENTITY(1,1)
CONSTRAINT PK_YourTable PRIMARY KEY CLUSTERED
END
GO
Alter table /**粘贴tabal的名称**/ 添加id int (1,1)
删除/**,粘贴tabal的名称**/ id在哪里
(
选择a.d id FROM /**粘贴tabal的名字/作为a 左外连接( SELECT MIN(id) as id 从/粘贴tabal的名称/ 集团 /粘贴列c1,c2 ....* * /
) as t1
ON a.id = t1.id
在t1。id为空
)
Alter table /**粘贴tabal的名称**/ DROP列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。