6

在我的带有 inno_db 引擎的 mysql 数据库上,

我有一个带有外键的表。我想删除该列(当然还有外键和相关索引 - 我不需要整个列!)

现在,简单地删除它会产生一个错误:General error: 1025 Error on rename of '.\road_dmy#sql-19d8_2be' to '.\road_dmy\contact' (errno: 150)

听起来这是一个已知问题。 http://bugs.mysql.com/bug.php?id=15317

但无论如何,我应该怎么做才能删除这个专栏?我很确定否则没有人会使用这个数据库

(顺便说一句,我怎么知道上面神秘错误信息的真实细节?)

4

1 回答 1

7

您必须先放下钥匙。我不知道您的表的名称,但我将通过示例为您提供一般策略。假设您有以下 2 个 InnoDB 表:

CREATE TABLE `A` (
   `id` int(10) unsigned NOT NULL auto_increment,
    PRIMARY KEY  (`id`)
) ENGINE=InnoDB;

CREATE TABLE `B` (
    `id` int(10) unsigned NOT NULL auto_increment,
    `a_id` int(10) unsigned NOT NULL,
    PRIMARY KEY  (`id`),
    KEY `a_id` (`a_id`),
    CONSTRAINT `b_ibfk_1` FOREIGN KEY (`a_id`) REFERENCES `a` (`id`)
) ENGINE=InnoDB;

您可以使用以下命令删除a_id表中的列:B

alter table B drop foreign key b_ibfk_1, drop column a_id;
于 2011-04-08T01:23:34.497 回答