如何自动增加SQL Server数据库表中的主键?我已经通过论坛看了一下,但不知道如何做到这一点。

我看了房子的属性,但找不到选项。我看到了一个答案,你去到身份规范属性,并将其设置为“是”,并将身份增量设置为1,但该部分是灰色的,我不能将“否”更改为“是”。

一定有一个简单的方法来做到这一点,但我找不到。


当前回答

您必须展开Identity部分以公开增量和种子。

编辑:我假设您的数据类型是整数,而不是char(10)。当我发布这个答案时,我想说哪个是合理的和有效的

其他回答

注意ID元素是否相邻。由于SQLSERVER ID可以跳跃1000。

例如:重启前ID=11 重新启动后,在表中插入新行,那么id将是1012。

当你使用Data Type: int时,你可以选择你想要自动递增的行,然后转到列属性标签。在这里,您可以将身份设置为“yes”。自动递增的起始值也可以在那里编辑。希望我能帮上忙;)

您可以执行以下操作:新建表:

-- create new table with Column ID which is Primary Key and Auto Increment --
    
CREATE TABLE titles(
      id INT NOT NULL IDENTITY(1,1) PRIMARY KEY,  --Primary Key with Auto-Increment --
      keyword        VARCHAR(260),
      status VARCHAR(10),
 );

如果你的表已经存在,并且需要对ID列进行自动递增和主键的更改,那么请参见下面的内容:

ALTER TABLE table DROP COLUMN id; // drop the existing ID in the table 
ALTER TABLE table ADD id int IDENTITY(1, 1) NOT NULL; // add new column ID with auto-increment
ALTER TABLE table ADD CONSTRAINT PK_ident_test PRIMARY KEY CLUSTERED (id); // make it primary key

您必须展开Identity部分以公开增量和种子。

编辑:我假设您的数据类型是整数,而不是char(10)。当我发布这个答案时,我想说哪个是合理的和有效的

如果已经填充了表,则无法将列更改为IDENTITY列或将其转换为非IDENTITY列。您将需要导出所有数据,然后您可以将列类型更改为IDENTITY,反之亦然,然后将数据导入回来。 我知道这是一个痛苦的过程,但我相信除了使用这篇文章中提到的序列之外没有其他选择。