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

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


当前回答

这在MariaDB中工作,所以我只能希望它在SQL Server中做到:删除刚刚插入的ID列,然后使用以下语法

增加表的主键

不需要另一张桌子了。这只是插入一个id列,使其成为主索引,并用顺序值填充它。如果SQL Server不这样做,我很抱歉浪费了你的时间。

其他回答

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

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

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

试试下面的代码:

DBCC CHECKIDENT ('settings', RESEED, 0) 

通过设计器你可以设置identity (1,1) 右击TBL => design =>在部分左击(右击)=>属性=>在标识列选择#列

属性

idendtity列

我遇到了这个问题,但不能使用标识列(由于各种原因)。 我决定这样做:

DECLARE @id INT
SET @id = 0 
UPDATE table SET @id = id = @id + 1 

从这里借的。