10

这是我的桌子:

CREATE TABLE `alums_alumphoto` (  
  `id` int(11) NOT NULL auto_increment,  
  `alum_id` int(11) NOT NULL,  
  `photo_id` int(11) default NULL,  
  `media_id` int(11) default NULL,  
  `updated` datetime NOT NULL,  
  PRIMARY KEY  (`id`),  
  KEY `alums_alumphoto_alum_id` (`alum_id`),  
  KEY `alums_alumphoto_photo_id` (`photo_id`),  
  KEY `alums_alumphoto_media_id` (`media_id`),  
  CONSTRAINT `alums_alumphoto_ibfk_1` FOREIGN KEY (`media_id`) REFERENCES `media_mediaitem` (`id`),  
  CONSTRAINT `alum_id_refs_id_706915ea` FOREIGN KEY (`alum_id`) REFERENCES `alums_alum` (`id`),  
  CONSTRAINT `photo_id_refs_id_63282119` FOREIGN KEY (`photo_id`) REFERENCES `media_mediaitem` (`id`)  
) ENGINE=InnoDB AUTO_INCREMENT=63 DEFAULT CHARSET=utf8  

我想删除 column photo_id,这可能还需要删除外键约束和索引。

问题是当我尝试删除列时出现错误:

错误 1025 (HY000): 将 '.\dbname\#sql-670_c5c' 重命名为 '.\dbname\alums_alumphoto' 时出错 (errno: 150)

...当我尝试删除索引(与上面相同)时,以及当我尝试删除外键约束时:

错误 1091 (42000): 不能 DROP 'photo_id_refs_id_63282119'; 检查列/键是否存在)

我应该按照什么顺序进行所有这些操作?我应该使用什么精确的命令?

4

3 回答 3

25

确切地说,试试这个:

首先删除外键或约束:

ALTER TABLE `alums_alumphoto` DROP FOREIGN KEY `photo_id_refs_id_63282119`;

前面的命令删除列上的外键约束。现在您可以删除列photo_id(删除列时 MySQL 删除了索引):

ALTER TABLE `alums_alumphoto` DROP COLUMN `photo_id`;

或者,您可以将这两个操作合并为一个:

ALTER TABLE `alums_alumphoto` 
   DROP FOREIGN KEY `photo_id_refs_id_63282119` , 
   DROP COLUMN `photo_id`;
于 2008-12-04T14:13:57.440 回答
7

确定的是制作一个重复的表。

> CREATE TABLE alums_alumphoto_new LIKE alums_alumphoto;
> ALTER TABLE .... // Drop constraint
> ALTER TABLE .... // Drop KEY
> ALTER TABLE .... // Drop the column
> INSERT INTO alums_alumphoto_new (SELECT id, alum_id, photo_id, media_id, updated FROM alums_alumphoto);
> RENAME TABLE alums_alumphoto TO alums_alumphoto_old, alums_alumphoto_new TO alums_alumphoto;

如果执行 RENAME TABLE 时出错,则其他一些表可能具有引用该表的外键约束,在这种情况下,整个方法是愚蠢的。:)

于 2008-12-03T22:42:29.193 回答
0

尝试结合使用 DROP KEY 和 DROP FOREIGN KEY 语句。

ALTER TABLE `alums_alumphoto` 
    DROP KEY KEY `alums_alumphoto_photo_id`,
    DROP FOREIGN KEY `photo_id_refs_id_63282119`;

ALTER TABLE `alums_alumphoto` 
    DROP COLUMN `photo_id`;
于 2008-12-17T18:20:59.293 回答