我有一个由大约8个相关表组成的Microsoft Sql Server数据库,我正在尝试更新它。为此,我创建了许多临时表。
"CREATE TABLE [vehicle_data].[dbo].[temp_MAINTENANCE_EVENT] (" +
"[maintenance_event_id] int," +
"[maintenance_computer_code_id] int," +
"[veh_eng_maintenance_id] int," +
"CONSTRAINT [PK_maintenance_event_id"] PRIMARY KEY CLUSTERED ([maintenance_event_id] ASC))";
然后,当所有临时表被创建后,我删除现有的表,重命名临时表,并为新表添加外键和索引以加快连接和查询速度。
我的问题是原始主键引用仍然存在。因此,当我再次更新时,会出现“异常:数据库中已经存在一个名为'PK_maintenance_event_id'的对象。无法创建约束。”
我想知道最好的做法是什么?我是否应该在创建临时表时不设置主键,而是在将其重命名后向表中添加主键?或者是否有一种方法可以重命名约束,以便在重命名表时更改主键约束的名称。
在原始表被删除后,我希望停机时间尽可能短,但在表被删除之前发生的任何事情都可能需要很长时间,这并不重要。
CONSTRAINT [name..]
部分即可。 - RBarryYoung