Отношение ко многим Laravel - PullRequest
0 голосов
/ 06 января 2020

что я делаю не так? Очень простой пример:

Модель разрешений:

namespace App;

use Illuminate\Database\Eloquent\Model;

class Permission extends Model
{
    protected $fillable=['name'];
    public function roles()
    {
        return $this->belongsToMany('App\Role', 'role_permission')->withTimestamps();
    }
}

Ролевая модель:

<?php

namespace App;

use Illuminate\Database\Eloquent\Model;

class Role extends Model
{
    protected $fillable=['name'];
    public function permissions()
    {
        return $this->belongsToMany('App\Permission', 'role_permission')->withTimestamps();
    }
}

Ролевая миграция:

<?php

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

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

    /**
     * Reverse the migrations.
     *
     * @return void
     */
    public function down()
    {
        Schema::dropIfExists('roles');
    }
}

Миграция разрешений:

<?php

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

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

    /**
     * Reverse the migrations.
     *
     * @return void
     */
    public function down()
    {
        Schema::dropIfExists('permissions');
    }
}

миграция role_permission:

<?php

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

class CreateRolePermissionTable extends Migration
{
    /**
     * Run the migrations.
     *
     * @return void
     */
    public function up()
    {
        Schema::create('role_permission', function (Blueprint $table) {
            $table->unsignedBigInteger('role_id');
            $table->foreign('role_id')->references('id')->on('roles');
            $table->unsignedBigInteger('permission_id');
            $table->foreign('permission_id')->references('id')->on('permissions');
            $table->timestamps();
        });
    }

    /**
     * Reverse the migrations.
     *
     * @return void
     */
    public function down()
    {
        Schema::dropIfExists('role_permission');
    }
}

Artisan Tinker:

>>> $p=new App\Permission
=> App\Permission {#3009}
>>> $r=new App\Role
=> App\Role {#3003}
>>> $p->first()
=> App\Permission {#3017
     id: 1,
     name: "permisja",
     created_at: "2020-01-06 01:20:34",
     updated_at: "2020-01-06 01:20:34",
   }
>>> $r->first()
=> App\Role {#3021
     id: 1,
     name: "rola",
     created_at: "2020-01-06 01:20:39",
     updated_at: "2020-01-06 01:20:39",
   }
>>> $r->permissions()->attach(1)
Illuminate/Database/QueryException with message 'SQLSTATE[23000]: Integrity constraint violation: 1048 Column 'role_id' cannot be null (SQL: insert into `role_permission` (`created_at`, `permission_id`, `role_id`, `updated_at`) values (2020-01-06 01:24:16, 1, ?, 2020-01-06 01:24:16))'

Это просто код, и я делаю все, что вижу в курсе. Couse основан на Laravel 5, но у меня Laravel 6, может в этом проблема? Пожалуйста, помогите!

1 Ответ

1 голос
/ 06 января 2020

$ r по-прежнему является экземпляром нового App \ Role , а не $ r-> first ()

Вы пропустили присвоение $ r-> first () к переменной.

Попробуйте

$rl = $r->first();
$rl->permissions()->attach(1)

или $r->first()->permissions()->attach(1)

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...