如何更改 SQL 服务器中主键的列长度?
How to change the column length of a primary key in SQL Server?
我知道如何更改列的长度,但是我的 SQL 语句失败了,因为我要更改的列是 PK,所以我收到以下错误:
Msg 5074, Level 16, State 1, Line 1
The object 'PK_TableName' is dependent on column 'PersonID'.
PersonID = PK。
我读过 What is the sql to change the field length of a table column in sql server,它仅适用于非 PK 列。
我试过这个:
ALTER TABLE table_name
ALTER COLUMN column_name <new datatype>
ALTER TABLE <Table_Name>
DROP CONSTRAINT <constraint_name>
ALTER TABLE table_name
ALTER COLUMN column_name datatype
ALTER TABLE <Table_Name>
ADD CONSTRAINT <constraint_name> PRIMARY KEY (<Column1>,<Column2>)
请参阅下面的示例示例如何增加主列的大小
创建样本table
create table abc (id varchar(10) primary key)
在键约束中找到主约束 tables
select object_name(object_id),* from sys.key_constraints where object_name(parent_object_id) = 'abc
删除约束
ALTER TABLE abc
DROP CONSTRAINT PK__abc__3213E83F74EAC69B
(将 PK__abc__3213E83F74EAC69B 替换为您收到的约束名称。)
添加不为空
ALTER TABLE abc alter column id varchar(20) NOT NULL;
再次添加主键
ALTER TABLE abc
ADD CONSTRAINT MyPrimaryKey PRIMARY KEY (id)
SQLServer 2008 不允许我用数据更改主键,所以我停用了所有约束,执行了命令并再次激活了所有约束。命令是:
EXEC sp_MSforeachtable @command1="ALTER TABLE ? NOCHECK CONSTRAINT ALL"
-- commands here
EXEC sp_MSforeachtable @command1="ALTER TABLE ? CHECK CONSTRAINT ALL"
我知道如何更改列的长度,但是我的 SQL 语句失败了,因为我要更改的列是 PK,所以我收到以下错误:
Msg 5074, Level 16, State 1, Line 1
The object 'PK_TableName' is dependent on column 'PersonID'.
PersonID = PK。
我读过 What is the sql to change the field length of a table column in sql server,它仅适用于非 PK 列。
我试过这个:
ALTER TABLE table_name
ALTER COLUMN column_name <new datatype>
ALTER TABLE <Table_Name>
DROP CONSTRAINT <constraint_name>
ALTER TABLE table_name
ALTER COLUMN column_name datatype
ALTER TABLE <Table_Name>
ADD CONSTRAINT <constraint_name> PRIMARY KEY (<Column1>,<Column2>)
请参阅下面的示例示例如何增加主列的大小
创建样本table
create table abc (id varchar(10) primary key)
在键约束中找到主约束 tables
select object_name(object_id),* from sys.key_constraints where object_name(parent_object_id) = 'abc
删除约束
ALTER TABLE abc DROP CONSTRAINT PK__abc__3213E83F74EAC69B
(将 PK__abc__3213E83F74EAC69B 替换为您收到的约束名称。)
添加不为空
ALTER TABLE abc alter column id varchar(20) NOT NULL;
再次添加主键
ALTER TABLE abc ADD CONSTRAINT MyPrimaryKey PRIMARY KEY (id)
SQLServer 2008 不允许我用数据更改主键,所以我停用了所有约束,执行了命令并再次激活了所有约束。命令是:
EXEC sp_MSforeachtable @command1="ALTER TABLE ? NOCHECK CONSTRAINT ALL"
-- commands here
EXEC sp_MSforeachtable @command1="ALTER TABLE ? CHECK CONSTRAINT ALL"