В Laravel 5 миграция для удаления составного уникального ключа не работает

Попытка выполнить миграцию для удаления составного уникального ключа завершится неудачно без ошибок.

Я создал миграцию с php artisan make:migration и отредактировал код. Итак, у меня есть это

public function up()
{
    Schema::table('ques_trilha_itens', function (Blueprint $table) {
        $table->dropUnique('trilha_itens_trilha_id_questao_id_unique');
    });
}

/**
 * Reverse the migrations.
 *
 * @return void
 */
public function down()
{
    Schema::table('ques_trilha_itens', function (Blueprint $table) {
        $table->unique(['trilha_id', 'questao_id']);
    });
}

Строка 'trilha_itens_trilha_id_questao_id_unique' это тот, который отображается как составной уникальный ключ в MySQL. Так что я думаю, что строка должна быть использована, отбросьте два составных ключа.

Но когда работает php artisan migrate, ничего не происходит, никаких сообщений об ошибках, и миграция не выполняется.

Я попытался заменить строку в dropUnique дать имя таблицы в качестве первого термина ('ques_trilha_itens_trilha_id_questao_id_unique') и ничего.

Что-то мне не хватает?

ОБНОВЛЕНИЕ:

Команда MySQL SHOW CREATE TABLE ques_trilha_itens дать:

CREATE TABLE `ques_trilha_itens` (
  `id` int(10) unsigned NOT NULL AUTO_INCREMENT,
  `trilha_id` int(10) unsigned NOT NULL,
  `questao_id` int(10) unsigned NOT NULL,
  `primeiro_item` tinyint(1) NOT NULL,
  `item_principal_id` int(10) unsigned DEFAULT NULL,
  `created_at` timestamp NOT NULL DEFAULT '0000-00-00 00:00:00',
  `updated_at` timestamp NOT NULL DEFAULT '0000-00-00 00:00:00',
  `chave` varchar(50) COLLATE utf8_unicode_ci DEFAULT NULL,
  `deleted_at` timestamp NULL DEFAULT NULL,
  PRIMARY KEY (`id`),
  UNIQUE KEY `trilha_itens_trilha_id_questao_id_unique` (`trilha_id`,`questao_id`),
  UNIQUE KEY `ques_trilha_itens_chave_unique` (`chave`),
  KEY `trilha_itens_questao_id_foreign` (`questao_id`),
  KEY `ques_trilha_itens_item_principal_id_foreign` (`item_principal_id`),
  CONSTRAINT `ques_trilha_itens_item_principal_id_foreign` FOREIGN KEY (`item_principal_id`) REFERENCES `ques_trilha_itens` (`id`) ON DELETE SET NULL,
  CONSTRAINT `trilha_itens_trilha_id_foreign` FOREIGN KEY (`trilha_id`) REFERENCES `ques_trilhas` (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=43 DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci

2 ответа

Ну, методом проб и ошибок я выяснил, чего мне не хватало.

Проблема в том, что MySQL не любит, когда вы пытаетесь удалить составной ключ с внешней ссылкой до того, как вы удалите сами эти внешние ключи ранее.

CONSTRAINT `ques_trilha_itens_item_principal_id_foreign` FOREIGN KEY (`item_principal_id`) REFERENCES `ques_trilha_itens` (`id`) ON DELETE SET NULL,
CONSTRAINT `trilha_itens_trilha_id_foreign` FOREIGN KEY (`trilha_id`) REFERENCES `ques_trilhas` (`id`)

Таким образом, мы должны отбросить индекс (KEY) раньше тоже.

KEY `trilha_itens_questao_id_foreign` (`questao_id`)

Только после этого я мог сбросить составленные ключи ['questao_id', 'trilha_id'],

В конце концов, моя миграция была такой

/**
 * Run the migrations.
 *
 * @return void
 */

public function up()
    {
        Schema::table('ques_trilha_itens', function (Blueprint $table) {
            // Remove chaves estrangeiras, índices e chaves não estrangeiras
            $table->dropForeign('trilha_itens_questao_id_foreign');
            $table->dropForeign('trilha_itens_trilha_id_foreign');
            $table->dropIndex('trilha_itens_questao_id_foreign');
            $table->dropUnique('trilha_itens_trilha_id_questao_id_unique');

            // Refaz relações, agora sem a chave dupla
            $table->foreign('questao_id')->references('id')->on('ques_questoes');
            $table->foreign('trilha_id')->references('id')->on('ques_trilhas');
        });
}

/**
 * Reverse the migrations.
 *
 * @return void
 */
public function down()
{
    Schema::table('ques_trilha_itens', function (Blueprint $table) {
        $table->unique(['questao_id', 'trilha_id']);
    });
}

Я пытался понять, что происходит, потом пришло ко мне.

это твоя проблема

$table->dropUnique('trilha_itens_trilha_id_questao_id_unique'); <<< here be the problem

Ваша проблема в том, что вы пытаетесь сделать слишком много вещей одновременно.

бросить уникальный ключ. Вы должны использовать соответствующую номенклатуру.

table_name_column_name_unique 1) table_name _ 2) column_name _ 3) уникальный

так что вам придется запускать свой dropUnique () дважды.

$table->dropUnique('trilha_itens_trilha_id_unique'); //for trilha_id
$table->dropUnique('trilha_itens_questao_id_unique'); //for questao_id

Попробуйте, дайте мне знать, как это происходит. Конечно, убедитесь, что вы запускаете composer dump-autoload Happy coding:)

крупный чиновник

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