SQLSTATE [42S22]: Столбец не найден: 1054 Неизвестный столбец «имя» в «предложении где» (SQL: выбрать * из «ролей», где «имя» = ограничение пользователя 1) - PullRequest
0 голосов
/ 23 апреля 2019

Я создаю нового пользователя, заполнив все поля, а затем, когда я отправляю все новые данные для пользователя, регистрируются с правильными данными в БД, но я не перенаправляюсь на страницу индекса; я получаю эту ошибку:

SQLSTATE [42S22]: столбец не найден: 1054 Неизвестный столбец «имя» в «предложении где» (SQL: выберите * из roles, где name = ограничение пользователя 1)

thisмоя модель пользователя:

<?php

namespace App;

use Illuminate\Notifications\Notifiable;
use Illuminate\Foundation\Auth\User as Authenticatable;

class User extends Authenticatable
{
    use Notifiable;



    /**
     * The attributes that are mass assignable.
     *
     * @var array
     */
    protected $fillable = [
        'name', 'email','user_type', 'password'
    ];

    /**
     * The attributes that should be hidden for arrays.
     *
     * @var array
     */
    protected $hidden = [
        'password', 'remember_token',
    ];
}

это моя модель для подражания:

<?php

namespace App;

use Illuminate\Database\Eloquent\Model;

class Roles extends Model
{
    //


     protected $fillable = [
        'libelle'
    ];
}

это мой пользовательский контроллер:

<?php

namespace App\Http\Controllers;

use Illuminate\Http\Request;
use Illuminate\Support\Facades\Hash;


use Auth;
use App\User;

class UserController extends Controller
{
    /**
     * Display a listing of the resource.
     *
     * @return \Illuminate\Http\Response
     */

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

    public function getRowAttributes()
    {
        return view('manage_users.index');
    }



    /**
     * Show the form for creating a new resource.
     *
     * @return \Illuminate\Http\Response
     */

    //ouvrir le formulaire
    public function create()
    {
        return view('manage_users/create');
    }

    /**
     * Store a newly created resource in storage.
     *
     * @param  \Illuminate\Http\Request  $request
     * @return \Illuminate\Http\Response
     */


    //save data 
    public function store(Request $request)
    {
        $this->validate($request,[

              'name' => 'required|string|max:255',
            'email' => 'required|string|email|max:255',
            'user_type' => 'required',
            'password' => 'required|string|min:6|confirmed'
        ]);

        $user=new User([
              'name' => $request->get('name'),
             'email' => $request->get('email'),
             'user_type'  => $request->get('user_type'),
             'password' => bcrypt($request->get('password'))

        ]);
        $user->save();
        return redirect('manage_users/index')->with('success','Data Added');

    }

    /**

это моя роль Контроллер:

<?php

namespace App\Http\Controllers;

use Illuminate\Http\Request;

use App\Roles;

class RolesController extends Controller
{
    //
public function __construct()
{
    $this->middleware('auth');
}
      public function index()
    {
        $roles = Roles::all();

        return view('manage_users.create', ['roles' => $roles]);
    }


}

это мой маршрут в web.php


Route::get('manage_users/index', 'UserController@getRowAttributes')->name('index');


//Route::get('manage_users/column_search', 'UserController@getColumnSearch')->name('column_search');

//Route::get('manage_users/index','UserController@index');

//Route::resource('manage_users','UserController');

Route::get('manage_users/create','UserController@create');
Route::get('manage_users/create','RolesController@index');
Route::post('manage_users/create','UserController@store');
//Route::get('manage_users/index','UserController@index');

SQLSTATE [42S22]: столбец не найден: 1054 Неизвестный столбец «имя» в «где предложение» (SQL: выбор* с roles где name = пользовательский лимит 1)

Ответы [ 2 ]

0 голосов
/ 23 апреля 2019

Как я вижу ниже код на User модели

protected $fillable = [
    'name', 'email','user_type', 'password'
];

Кажется, вы добавили столбец name в таблицу users,

Вы также должны добавить столбец name в таблицу roles, выполнив следующие шаги

ШАГИ НА СЛЕДУЮЩУЮ:

1. Запустите команду: php artisan make:migration alter_table_roles_add_name_column // Это создаст новый файл миграции

2.Добавьте приведенные ниже методы в новый файл миграции

public function up()
{
    Schema::table('roles', function (Blueprint $table) {
        $table->string('name')
        ->after('id'); //optional
    });
}


public function down()
{
    Schema::table('roles', function (Blueprint $table) {
        $table->dropColumn('name');
    });
}

3.Наконец запустить команду: php artisan migrate

Я надеюсь, что это решит вашу проблему

0 голосов
/ 23 апреля 2019

Ваша таблица roles не имеет столбца name.

Попробуйте следовать и посмотрите, что вы получите.Откройте оболочку тинкера:

php artisan tinker

Если приведенный ниже код возвращает ту же ошибку.Проверьте свои миграции.Это означает, что name столбец отсутствует.

\DB::table('roles')->where('name', 1)->get();
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...