Laravel :: Лучший способ обновить внешний ключ

11

У меня есть этот файл миграции

Schema::create('table_one', function(Blueprint $table) 
{ 
    $table->increments('id'); 
    $table->string('name'); 
    $table->integer('table_two_id')->unsigned(); 
    $table->foreign('table_two_id')->references('id')->on('table_two'); 
    $table->timestamps(); 
});

и я хочу обновить его, чтобы сделать его → onDelete ('cascade');

$table->foreign('table_two_id')->references('id')->on('table_two')->onDelete('cascade');

Каков наилучший способ сделать это?

Есть ли что-то вроде → change();

Спасибо

Теги:
database
laravel-5.1

1 ответ

18
Лучший ответ

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

public function up()
{
    Schema::table('table_one', function (Blueprint $table) {
        $table->dropForeign('table_two_id');

        $table->foreign('table_two_id')
            ->references('id')
            ->on('table_two')
            ->onDelete('cascade');
    });
}
  • 0
    Это имеет смысл, потому что MySQL будет делать то же самое, в этом случае нет «изменений» в MySQL. Тем не менее, я ожидаю, что обертка / single_command на уровне Laravel для такой ситуации. Благодарю.

Ещё вопросы

Сообщество Overcoder
Наверх
Меню