作为标题,我有一个已经填充了150000条记录的现有表。我添加了一个Id列(目前为空)。
我假设我可以运行一个查询,用增量数字填充这个列,然后设置为主键并打开自动增量。这是正确的做法吗?如果是,我怎么填入初始数字?
作为标题,我有一个已经填充了150000条记录的现有表。我添加了一个Id列(目前为空)。
我假设我可以运行一个查询,用增量数字填充这个列,然后设置为主键并打开自动增量。这是正确的做法吗?如果是,我怎么填入初始数字?
当前回答
我遇到了这个问题,但不能使用标识列(由于各种原因)。 我决定这样做:
DECLARE @id INT
SET @id = 0
UPDATE table SET @id = id = @id + 1
从这里借的。
其他回答
创建一个具有不同名称和相同列、主键和外键关联的新表,并将其链接到代码的Insert语句中。 对于EMPLOYEE,替换为EMPLOYEES。
CREATE TABLE EMPLOYEES(
EmpId INT NOT NULL IDENTITY(1,1),
F_Name VARCHAR(20) ,
L_Name VARCHAR(20) ,
DOB DATE ,
DOJ DATE ,
PRIMARY KEY (EmpId),
DeptId int FOREIGN KEY REFERENCES DEPARTMENT(DeptId),
DesgId int FOREIGN KEY REFERENCES DESIGNATION(DesgId),
AddId int FOREIGN KEY REFERENCES ADDRESS(AddId)
)
但是,您必须删除现有的EMPLOYEE表,或者根据您的需求进行一些调整。
不-你必须以另一种方式来做:从一开始就添加它为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
您不能“打开”IDENTITY:这是一个表重建。
如果您不关心数字顺序,您可以用IDENTITY一次性添加列NOT NULL。15万行不是很多。
如果您需要保留一些数字顺序,那么相应地添加数字。然后使用SSMS表设计器设置IDENTITY属性。这允许您生成一个脚本,该脚本将为您执行列删除/添加/保留数字/重新播种。
当我们在现有表中添加一个标识列时,它将自动填充,而不需要手动填充。