【发布时间】:2016-04-28 17:39:30
【问题描述】:
我可以在已经有一个主键的表中添加一个新列,以便新列和现有主键形成一个复合主键吗?
【问题讨论】:
标签: sql oracle composite-primary-key
我可以在已经有一个主键的表中添加一个新列,以便新列和现有主键形成一个复合主键吗?
【问题讨论】:
标签: sql oracle composite-primary-key
您不能直接执行此操作 - 您必须删除现有主键并创建一个新主键。请注意,主键列不得为null。例如:
-- Add the new column
-- Make sure it doesn't have any nulls in it
ALTER TABLE mytable ADD newcolumn NUMBER(10) NOT NULL DEFAULT 1;
-- Drop the primary key
ALTER TABLE mytable DROP PRIMARY KEY;
-- Add a new primary key
ALTER TABLE mytable ADD CONSTRAINT mytable_pk
PRIMARY KEY (oldcolumn1, oldcolumn2, newcolumn);
【讨论】: