Laravel SQLSTATE[42S02]:未找到基表或视图:1146 table';pk5.角色';不';不存在

Laravel SQLSTATE[42S02]:未找到基表或视图:1146 table';pk5.角色';不';不存在,laravel,Laravel,我可以通过tinker将记录插入员工角色,但无法通过代码插入 Role.php <?php namespace App\Models\Admin\Employee; use Illuminate\Database\Eloquent\Model; class Role extends Model { protected $table = 'employee_roles'; public function permissions() { ret

我可以通过tinker将记录插入员工角色,但无法通过代码插入

Role.php

<?php

namespace App\Models\Admin\Employee;

use Illuminate\Database\Eloquent\Model;

class Role extends Model
{

    protected $table = 'employee_roles';

    public function permissions()
    {
        return $this->belongsToMany('App\Models\Admin\Employee\Permission', 'employee_permission_role', 'role_id', 'permission_id');
    }
}
<?php

namespace App\Http\Controllers\Admin\Employee;

use App\Http\Controllers\Controller;
use Illuminate\Http\Request;
use App\Models\Employee\Employee;
use App\Models\Admin\Employee\Role;
use App\Models\Admin\Employee\Permission;

class RoleController extends Controller
{

    public function __construct()
    {
        $this->middleware('auth:admin');
    }

    public function index()
    {
        $roles = Role::all();
        return view('admins.employees.roles.role', compact('roles'));
    }

    public function create()
    {
      $permissions = Permission::all();
      return view('admins.employees.roles.create',compact('permissions'));
    }

    public function store(Request $request)
    {

      //dd($request);
        $this->validate($request, [
          'name' => 'required|unique:roles'
        ]);

        $role = new Role();
        $role->name = $request['name'];
        $role->save();
        $role->permissions()->sync($request->permission);

        return redirect(route('admin.employee.role.index'));
    }
@extends('layouts.admin')

@section('title', 'Role - Create')

@section('left-menu')

@endsection

@section('right-menu')

@endsection

@section('content')
  <h1>Add an Employee Role</h1>
  <br><br>
  @if ($errors->any())
    <div class="alert alert-danger">
        <ul>
            @foreach ($errors->all() as $error)
                <li>{{ $error }}</li>
            @endforeach
        </ul>
    </div>
  @endif
  <form action="{{ route('admin.employee.role.store') }}" method="post">
        @csrf

      <div class="form-group">
        <label for="name">Role Name</label>
        <input type="text" class="form-control" id="name" name="name" placeholder="Role Name" value="{{ old('name') }}">
      </div>

      <div class="form-row">
        <div class="col-md-4">
          <label for="name"><b>Customer Permissions</b></label>
            @foreach ($permissions as $permission)
              @if ($permission->for == 'Customer')
                <div class="checkbox">
                  <label><input type="checkbox" name="permission[]" value="{{ $permission->id }}">{{ $permission->name }}</label>
                </div>
              @endif
            @endforeach
        </div>

        <div class="col-md-4">
          <label for="name"><b>Despatch Permissions</b></label>
            @foreach ($permissions as $permission)
              @if ($permission->for == 'Despatch')
                <div class="checkbox">
                  <label><input type="checkbox" name="permission[]" value="{{ $permission->id }}">{{ $permission->name }}</label>
                </div>
              @endif
            @endforeach
        </div>
      </div>

    <div class="form-group">
      <button type="submit" class="btn btn-primary">Submit</button>
      <a href='{{ route('admin.employee.role.index') }}' class="btn btn-warning">Back</a>
    </div>

  </form>
@endsection

@section('pagescript')

@stop

您应该将表名固定为
employee\u角色


因为您没有表作为
角色
您说在您的角色模型中您使用的是
员工角色
表(
受保护的$table='employee\u roles';

您能展示一下您在tinker中所做的工作和您得到的输出吗?您的表名是什么?确保我们的表名是复数形式。
$this->validate($request, [
       'name' => 'required|unique:roles'
]);