Laravel创建表错误

时间:2016-03-27 17:10:49

标签: mysql laravel

vagrant@homestead:~/www/laravel$ php artisan migrate

当我运行代码时,不会创建最新的数据库表。

工作:

  • 角色
  • 权限
  • permission_role

错误:

  • ROLE_USER

enter image description here

我编码数据库迁移..

use Illuminate\Database\Schema\Blueprint;
use Illuminate\Database\Migrations\Migration;

class CreateRolePermissions extends Migration
{
    /**
     * Run the migrations.
     *
     * @return void
     */
    public function up()
    {
        Schema::create('roles', function(Blueprint $table){
            $table->increments('id');
            $table->string('name');
            $table->string('label');
            $table->timestamps();

        });

        Schema::create('permissions', function(Blueprint $table){
            $table->increments('id');
            $table->string('name');
            $table->string('label');
            $table->timestamps();

        });

        Schema::create('permission_role', function(Blueprint $table){
            $table->integer('role_id')->unsigined();
            $table->integer('permission_id')->unsigined();

            $table->foreign('role_id')
                ->referance('id')
                ->on('roles')
                ->onDelete('cascade');

            $table->foreign('permission_id')
                ->referance('id')
                ->on('permissions')
                ->onDelete('cascade');

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

        });

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

            $table->foreign('role_id')
                ->referance('id')
                ->on('roles')
                ->onDelete('cascade');

            $table->foreign('user_id')
                ->referance('id')
                ->on('users')
                ->onDelete('cascade');

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

        });

    }

    /**
     * Reverse the migrations.
     *
     * @return void
     */
    public function down()
    {
        \DB::statement('SET FOREIGN_KEY_CHECKS = 0');

        Schema::drop('roles');
        Schema::drop('permissions');
        Schema::drop('permission_role');
        Schema::drop('role_user');

        \DB::statement('SET FOREIGN_KEY_CHECKS = 1');

    }
}

如果你能帮我解决这个问题,我很高兴。

感谢。

1 个答案:

答案 0 :(得分:3)

应该是->references(),而不是->referance()

https://laravel.com/docs/5.1/migrations#foreign-key-constraints