некоторые данные не могут быть вставлены в базу данных

#php #database #laravel

#php #База данных #laravel

Вопрос:

Когда новый пользователь заполняет регистрационную форму и нажимает отправить, я могу получить все данные, которые мне нужны, используя dd ($ var). Но при вставке в базу данных laravel сообщает, что не удается вставить значение NULL в столбец ‘password’ . Почему laravel не получил мой пароль при вставке в базу данных?

я понятия не имею, что я здесь сделал не так. помогите мне..

это мой RegisterController.php

 protected function create(array $data)
{
    $pw_hash     = Hash::make($data['Password']);
    $uuid4       = Uuid::uuid4();


    $a = DB::table('Person.Person')->insert(array(
        'PersonId'      => $uuid4->toString(),
        'PersonName'    => $data['PersonName'],
        'Email'         => $data['Email'],
        'IsActive'      => false,
        'IsLoginActive' => false,
        'PasswordSalt'  => substr($pw_hash, 7, 22),
        'PasswordHash'  => sha1($pw_inpt.''.$pw_salt),
        'IsMale'        => $data['IsMale'],
        'Email'         => $data['Email'],
        'Phone'         => $data['Phone'],
        'LoginName'     => $data['Email'],
        'PersonName'    => $data["NamaDepan"]." ".$data['NamaBelakang'],
        'EmailVerifiedAt'   => date('Y-m-d'),
        'EmailVerified'     => false,
        'EmailVerificationCode'=> Hash::make(rand(0,100)),
        'password'=> 'aaaapass',
    ));

    dd($a);
}
  

и это мой User.php Модель

 class User extends Authenticatable{
use Notifiable;

protected $table        = 'Person.Person';
// protected $username     = 'Email';

public $incrementing    = false;
protected $primaryKey   = 'PersonId';

const CREATED_AT = 'CreatedDate';
const UPDATED_AT = 'ModifiedDate';

/**
 * The attributes that are mass assignable.
 *
 * @var array
 */
protected $fillable = [
    'PersonId',
    'Email',
    'Phone',
    'IsMale',
    'password',
    'IsActive',
    'Position',
    'LoginName',
    'kencur',
    'ClusterId',
    'BirthDate',
    'BirthPlace',
    'PersonName',
    'PersonImage',
    'PasswordSalt',
    'PasswordHash',
    'ModifiedDate',
    'IsLoginActive',
    'EmailVerified',
    'WhatsappNumber',
    'EmailVerifiedAt',
    'EmailVerificationCode',
];

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

public function getEmailForPasswordReset() {
    return $this->Email;
} 
}
  

и это то, что говорит laravel:

 Cannot insert the value NULL into column 'password', table 'Assess2.Person.Person'; column does not allow nulls. INSERT fails. (SQL: insert into [Person].[Person] ([PersonId], [PersonName], [Email], [IsActive], [IsLoginActive], [PasswordSalt], [PasswordHash], [IsMale], [Phone], [LoginName], [EmailVerifiedAt], [EmailVerified], [EmailVerificationCode], [password]) values (f6377aeb-df36-4f38-aef5-40c7a2240cc5, has sutenan, namadcvbepan@gmail.com, 0, 0, CTDdYYCXHULY4ad8jQJ9WO, $2y$10$CTDdYYCXHULY4ad8jQJ9WOmVqCILEuJPHSgffLlVW5SK7b7Q4qMpy, true, 55, namadcvbepan@gmail.com, 2019-03-04, 0, $2y$10$vcHlXQgukHomPI.FJZe2XOyl0lJd3Lo5rDqVN5SU8gY3UloPLsr.C, aaaapass))
  

я использую laravel 5.7. спасибо

Комментарии:

1. print_r перед сохранением в БД посмотрите, что вы на самом деле отправляете в БД. посмотрите, соответствуют ли данные вашим требованиям

Ответ №1:

ПАРОЛЬ — это зарезервированное ключевое слово базы данных. Попробуйте переименовать этот столбец.

Комментарии:

1. Проблема не в имени столбца, проблема в том, что OP пытается вставить NULL в этот столбец,

2. я не уверен, что password — это ключевое слово reserved в laravel, потому что я всегда использую ‘password’ для сохранения пароля пользователя в моем другом проекте.

3. привет @Kratos, но я не хочу вставлять null. проблема в том, что у меня есть данные [a, b, c, d], и я хочу вставить их все в свою базу данных. Но laravel просто вставляет [a, b, d],

4. извините, я имел в виду, что laravel отправляет null, вы пробовали напечатать запрос?

5. похоже, что поле пароля не возвращается, попробуйте еще раз проверить свой html-код, чтобы избежать ошибок в написании пароля.