Неверное имя таблицы

Неверное имя таблицы

16.01.2020 11:58:35 Просмотров 36 Источник

Illuminate\Database\QueryException : SQLSTATE[42000]: синтаксическая ошибка или нарушение доступа: 1103 неверное имя таблицы "(SQL: create table " (idbigint unsigned not null auto_increme NT primary key, namevarchar (255) not null, guard_namevarchar (255) not null, created_attimestamp null, updated_attimestamp null) набор символов по умолчанию utf8mb4 collate ' utf8mb4 _unicode_ci')'

<?php

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

class CreatePermissionTables extends Migration
{
    /**
     * Run the migrations.
     *
     * @return void
     */
    public function up()
    {
        $tableNames = config('permission.table_names');
        $columnNames = config('permission.column_names');

        Schema::create($tableNames['permissions'], function (Blueprint $table) {
            $table->bigIncrements('id');
            $table->string('name');
            $table->string('guard_name');
            $table->timestamps();
        });

        Schema::create($tableNames['roles'], function (Blueprint $table) {
            $table->bigIncrements('id');
            $table->string('name');
            $table->string('guard_name');
            $table->timestamps();
        });

        Schema::create($tableNames['model_has_permissions'], function (Blueprint $table) use ($tableNames, $columnNames) {
            $table->unsignedBigInteger('permission_id');

            $table->string('model_type');
            $table->unsignedBigInteger($columnNames['model_morph_key']);
            $table->index([$columnNames['model_morph_key'], 'model_type'], 'model_has_permissions_model_id_model_type_index');

            $table->foreign('permission_id')
                ->references('id')
                ->on($tableNames['permissions'])
                ->onDelete('cascade');

            $table->primary(['permission_id', $columnNames['model_morph_key'], 'model_type'],
                    'model_has_permissions_permission_model_type_primary');
        });

        Schema::create($tableNames['model_has_roles'], function (Blueprint $table) use ($tableNames, $columnNames) {
            $table->unsignedBigInteger('role_id');

            $table->string('model_type');
            $table->unsignedBigInteger($columnNames['model_morph_key']);
            $table->index([$columnNames['model_morph_key'], 'model_type'], 'model_has_roles_model_id_model_type_index');

            $table->foreign('role_id')
                ->references('id')
                ->on($tableNames['roles'])
                ->onDelete('cascade');

            $table->primary(['role_id', $columnNames['model_morph_key'], 'model_type'],
                    'model_has_roles_role_model_type_primary');
        });

        Schema::create($tableNames['role_has_permissions'], function (Blueprint $table) use ($tableNames) {
            $table->unsignedBigInteger('permission_id');
            $table->unsignedBigInteger('role_id');

            $table->foreign('permission_id')
                ->references('id')
                ->on($tableNames['permissions'])
                ->onDelete('cascade');

            $table->foreign('role_id')
                ->references('id')
                ->on($tableNames['roles'])
                ->onDelete('cascade');

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

        app('cache')
            ->store(config('permission.cache.store') != 'default' ? config('permission.cache.store') : null)
            ->forget(config('permission.cache.key'));
    }

    /**
     * Reverse the migrations.
     *
     * @return void
     */
    public function down()
    {
        $tableNames = config('permission.table_names');

        Schema::dropIfExists($tableNames['role_has_permissions']);
        Schema::dropIfExists($tableNames['model_has_roles']);
        Schema::dropIfExists($tableNames['model_has_permissions']);
        Schema::dropIfExists($tableNames['roles']);
        Schema::dropIfExists($tableNames['permissions']);
    }
}

почему $tableNames [*** * * * * ] недопустимы

пожалуйста помочь :)

У вопроса есть решение - Посмотреть?

https://stackoverflow.com/questions/59777707/incorrect-table-name#comment105699746_59777707
Вы должны также поделиться своим конфигурационным файлом "разрешения"... способ конфигурации() будет пытаться открыть файл /настройки/разрешения.РНР ....

Ответы - Неверное имя таблицы / Incorrect table name

Является ответом!
Denis

17.01.2020 12:28:21

После того, как вы установили что-то в config, убедитесь, что вы запускаете : php artisan config:cache.

Я также предлагаю создать разные миграции для каждой таблицы, которая у вас есть. Это будет более управляемо, и теперь вы точно узнаете, какая миграция не удалась.

https://stackoverflow.com/questions/59777707/incorrect-table-name/59778062#comment105700368_59778062
спасибо, проблема решена :)
Закрыть X