Невозможно добавить ограничение внешнего ключа — Laravel Entrust

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

alter table `__acc_role_user` add constraint `__acc_role_user_user_id_foreign` foreign key (`user_id`) references `__acc_accounts` (`account_id`) on delete cascade on update cascade

Как я создаю таблицу счетов?

    Schema::create('__acc_accounts', function($table)
{
$table->integer('account_id')->increments();
$table->integer('points')->default(0);

$table->foreign('account_id')->references('id')->on('accounts')->onDelete('cascade');
});

А затем поручите миграцию (ниже представлен только проблемный раздел):

    Schema::create('__acc_role_user', function (Blueprint $table) {
$table->integer('user_id')->unsigned();
$table->integer('role_id')->unsigned();

$table->foreign('user_id')->references('account_id')->on('__acc_accounts')
->onUpdate('cascade')->onDelete('cascade');
$table->foreign('role_id')->references('id')->on('__acc_roles')
->onUpdate('cascade')->onDelete('cascade');

$table->primary(['user_id', 'role_id']);
});

0

Решение

Этот синтаксис лучше:

/**
* Run the migrations.
*
* @return void
*/
public function up()
{
Schema::create('__acc_accounts', function($table)
{
$table->integer('account_id')->increments();
$table->integer('points')->default(0);
});

Schema::table('__acc_accounts', function(Blueprint $table)
{
$table->foreign('account_id')->references('id')->on('accounts')->onDelete('cascade');
});
}/**
* Reverse the migrations.
*
* @return void
*/
public function down()
{
Schema::drop('__acc_accounts');
}

И очень важно! В вашем порядке миграции должно быть: сначала создайте таблицу «учетные записи», а затем «__acc_accounts».

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

это http://blog.kongnir.com/2015/03/08/laravel-order-of-migrations-with-foreign-keys/ может помочь вам понять это.

1

Другие решения

Других решений пока нет …

По вопросам рекламы [email protected]