我已经使用auth命令来获取默认的登录页面和注册页面,并且已经对其进行了修改以适合数据库中的字段。但是当我尝试注册时出现错误:
“ SQLSTATE [HY000]:常规错误:1364字段'status'没有默认值(SQL:插入DataLoader
(users
,name
,{{1 }},email
,password
)值(“名称”,“电子邮件”,“加密密码”,日期,日期))“
我尝试将其设置为在迁移创建表上具有默认值,但问题仍然存在:
updated_at
这是我的注册控制器:
created_at
我的迁移表:
$table->string('status')->default('unapproved');
我的用户模型:
<?php
namespace App\Http\Controllers\Auth;
use App\User;
use App\Http\Controllers\Controller;
use Illuminate\Support\Facades\Hash;
use Illuminate\Support\Facades\Validator;
use Illuminate\Foundation\Auth\RegistersUsers;
class RegisterController extends Controller
{
use RegistersUsers;
protected $redirectTo = '/home';
public function __construct()
{
$this->middleware('guest');
}
protected function validator(array $data)
{
return Validator::make($data, [
'name' => ['required', 'string', 'max:255'],
'email' => ['required', 'string', 'email', 'max:255', 'unique:users'],
'password' => ['required', 'string', 'min:8', 'confirmed'],
]);
}
protected function create(array $data)
{
return User::create([
'name' => $data['name'],
'email' => $data['email'],
'password' => Hash::make($data['password']),
]);
}
}
就像我之前提到的那样,设置默认值后,我应该能够将用户插入表中,但是我得到“字段'status'没有默认值”错误,我认为这会发生在is_active上也一样,但是它在到达之前就失败了