繁体   English   中英

无法添加外键约束-Laravel Entrust

[英]Cannot add foreign key constraint - 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']);
    });

这种sintax更好:

/**
 * 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');
}

而且非常重要! 在您的迁移顺序中,必须是:首先创建表“ accounts”,然后创建“ __acc_accounts”。

具有外键的表应在创建它们所引用的表之后创建。

http://blog.kongnir.com/2015/03/08/laravel-order-of-migrations-with-foreign-keys/可以帮助您了解这一点。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM