【问题标题】:Base table or view not found: 1146 Table 'prj_oxbir.permissions' doesn't exist未找到基表或视图:1146 表 'prj_oxbir.permissions' 不存在
【发布时间】:2018-05-31 13:25:13
【问题描述】:

虽然文件夹中确实存在权限文件。为什么会显示此错误。

在 Connection.php 第 647 行:

SQLSTATE[42S02]:未找到基表或视图:1146 表 'prj_oxbir.permissions' 不存在(SQL: select * from permissions)

在 Connection.php 第 319 行:

SQLSTATE[42S02]:未找到基表或视图:1146 表 'prj_oxbir.permissions' 不存在

createrolestable.php

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

class CreateRolesTable 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')->nullable();
            $table->timestamps();
        });

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

        Schema::create('permission_role', function (Blueprint $table) {
            $table->integer('role_id')->unsigned();
            $table->foreign('role_id')->references('id')->on('roles')->onDelete('cascade');

            $table->integer('permission_id')->unsigned();
            $table->foreign('permission_id')->references('id')->on('permissions')->onDelete('cascade');

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

        Schema::create('role_user', function (Blueprint $table) {
            $table->integer('role_id')->unsigned();
            $table->foreign('role_id')->references('id')->on('roles')->onDelete('cascade');

            $table->integer('user_id')->unsigned();
            $table->foreign('user_id')->references('id')->on('users')->onDelete('cascade');

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

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

【问题讨论】:

  • 该错误是关于缺少数据库表,而不是文件夹中的文件...使用堆栈跟踪查找正在尝试查询 permissions 表的内容...因为您没有还没有进行迁移
  • 我该怎么办?谢谢

标签: mysql laravel


【解决方案1】:

首先,确保数据库中存在表permissions

其次,为permissions 表创建一个单独的迁移。

希望这会有所帮助。

【讨论】:

    猜你喜欢
    • 2015-12-23
    • 1970-01-01
    • 2020-07-20
    • 2017-07-22
    • 2018-10-17
    • 1970-01-01
    • 2014-10-08
    • 2019-01-28
    • 2017-08-02
    相关资源
    最近更新 更多