一尘不染

如何在SQL Server中更改主键的列长?

sql

我知道如何更改列的长度,但是我的SQL语句失败,因为我要更改的列是PK,因此出现以下错误:

消息5074,级别16,状态1,行1
对象“ PK_TableName”取决于列“ PersonID”。

PersonID = PK。

我已经阅读了什么SQL来更改仅适用于非PK列的sqlserver中表列的字段长度。

我尝试了这个:

ALTER TABLE table_name
ALTER COLUMN column_name <new datatype>

阅读 134

收藏
2021-05-16

共1个答案

一尘不染

请参见下面的示例示例,如何增加主列的大小

  1. 创建一个样本表

create table abc (id varchar(10) primary key)

  1. 在关键约束表中查找主要约束

select object_name(object_id),* from sys.key_constraints where object_name(parent_object_id) = 'abc

  1. 掉落约束

ALTER TABLE abc DROP CONSTRAINT PK__abc__3213E83F74EAC69B

(用收到的约束名称替换PK__abc__3213E83F74EAC69B。)

  1. 添加不为空

ALTER TABLE abc alter column id varchar(20) NOT NULL;

  1. 再次添加主键

ALTER TABLE abc ADD CONSTRAINT MyPrimaryKey PRIMARY KEY (id)

2021-05-16