Удаление столбца с внешним ключом

На моей базе данных MySQL с движком inno_db,

У меня есть таблица с внешним ключом. Я хочу удалить столбец (вместе с внешним ключом и соответствующим индексом, конечно - мне не нужен весь столбец!)

Теперь, просто отбрасывая его, выдается ошибка: Общая ошибка: 1025 Ошибка при переименовании файла ".\ Road_dmy#sql-19d8_2be" в ".\ Road_dmy\contact" (номер ошибки: 150)

Похоже, это известная проблема. http://bugs.mysql.com/bug.php?id=15317

Но в любом случае, что я должен сделать, чтобы отбросить этот столбец? Я уверен, что никто не мог бы использовать эту базу данных в противном случае

(и между прочим, как я могу узнать правдивые детали загадочного сообщения об ошибке выше?)

2 ответа

Решение

Сначала вы должны уронить ключ. Я не знаю названий ваших столов, но на примере приведу общую стратегию. Предположим, у вас есть следующие 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;

Чтобы просмотреть все внешние ключи, связанные с таблицей, используйте следующую команду:

      mysql> show create table <your_table_name>;

Эта команда выведет запрос на создание таблицы, содержащий ограничения внешнего ключа, например:

             Table: <your_table_name>
Create Table: CREATE TABLE `<your_table_name>` (
  `id` int DEFAULT NULL,
  `parent_id` int DEFAULT NULL,
  `unwanted_col` int DEFAULT NULL, 
  KEY `unwanted_col` (`unwanted_col`),
  CONSTRAINT `<your_table_name>_ibfk_1` FOREIGN KEY (`unwanted_col`)
  REFERENCES `parent_table` (`id`) ON DELETE CASCADE
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci

Теперь используйте команду ниже, чтобы удалить отношение внешнего ключа:

      mysql> ALTER TABLE <your_table_name> DROP FOREIGN KEY `<your_table_name>_ibfk_1`;

Теперь, когда ваше отношение внешнего ключа исчезло, вы можете безопасно удалить столбец:

      ALTER TABLE <your_table_name> DROP COLUMN unwanted_col;

См.:Удаление ограничений внешнего ключа.

Другие вопросы по тегам