SQLSTATE [HY000]: Общая ошибка: 1364 Поле «имя» не имеет значения по умолчанию в laravel - PullRequest
0 голосов
/ 25 мая 2020

Я использую mysql v5.7 и laravel v5.8. Я сделал функцию регистрации, используя auth, и когда я пытаюсь ее зарегистрировать, она показывает ошибку.

SQLSTATE [HY000]: Общая ошибка: 1364 Поле 'name' не имеет значения по умолчанию (SQL: insert в значения users (email, password, updated_at, created_at) (***@gmail.com, $ 2yd4Gv C, 2020-05-25 19:53:37, 2020- 05-25 19:53:37))

он отлично работает на localhost, но показывает эту ошибку после добавления на сервер ec2.

Я изменил config / database. php

вот так

'strict' => false,

тогда я могу зарегистрироваться, но в столбцах имени нет значения.

введите описание изображения здесь

и можно поместить другие столбцы, кроме столбца имени.

Я не знаю, почему он работает на локальном сервере, но показывает ошибку на живом сервере.

Это мой код.

Пользователь. php


class User extends Authenticatable
{
    use Notifiable;

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

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

    /**
     * The attributes that should be cast to native types.
     *
     * @var array
     */
    protected $casts = [
        'email_verified_at' => 'datetime',
    ];
}



create_users_table. php

    public function up()
    {
        Schema::create('users', function (Blueprint $table) {
            $table->bigIncrements('id');
            $table->string('name');
            $table->string('email')->unique();
            $table->timestamp('email_verified_at')->nullable();
            $table->string('password');
            $table->rememberToken();
            $table->timestamps();
        });
    }

Кто-нибудь может мне помочь?

1 Ответ

0 голосов
/ 25 мая 2020

Этот запрос:

INSERT INTO users (email, password, updated_at, created_at)
VALUES (***@gmail.com, $2yd4GvC, 2020-05-25 19:53:37, 2020-05-25 19:53:37)

не вставляет поле name. Когда это поле не может быть NULL, MySQL выдаст ошибку.

Причина, по которой вы не получаете эту ошибку на вашем локальном хосте, вероятно, заключается в том, что конфигурация MySQL менее строгая.

Настройка 'strict' => false, удалит ошибку, но ваш запрос по-прежнему не вставляет значения поля name.

Таким образом, реальное решение - сохранить строгую конфигурацию вашей базы данных (потому что тогда вы заметите ошибки намного быстрее). А затем измените свой запрос, чтобы он вставлял значение name.

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