播种机不工作laravel 5.2

时间:2015-12-23 23:55:50

标签: database laravel laravel-5 seeding

请考虑以下错误:

  [PDOException]                                                                                                 
  SQLSTATE[23502]: Not null violation: 7 ERROR:  null value in column "created_at" violates not-null constraint  
  DETAIL:  Failing row contains (5, Sample Name xxx@gmail.com, xxxxxx, null, null, null).  

这是播种机:

<?php

use Illuminate\Database\Seeder;

class AdminUser extends Seeder
{
    /**
     * Run the database seeds.
     *
     * @return void
     */
    public function run()
    {
        DB::table('users')->insert([
            'name'      => 'Sample Name',
            'email'     => 'xxxx@gmail.com',
            'password'  => 'xxxxxx',
        ]);
    }
}

用户模型:

class Users extends Model {
    protected $table        = 'users';
    protected $timestamps   = true;
    protected $fillable     = ['name', 'email', 'password', 'created_at', 'updated_at'];
}

怎么回事?迁移,默认来自laravel install:

<?php

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

class CreateUsersTable extends Migration
{
    /**
     * Run the migrations.
     *
     * @return void
     */
    public function up()
    {
        Schema::create('users', function (Blueprint $table) {
            $table->increments('id');
            $table->string('name');
            $table->string('email')->unique();
            $table->string('password', 60);
            $table->rememberToken();
            $table->timestamps();
        });
    }

    /**
     * Reverse the migrations.
     *
     * @return void
     */
    public function down()
    {
        Schema::drop('users');
    }
}

他们错过了什么吗?我有吗?

1 个答案:

答案 0 :(得分:4)

Eloquent模型会自动为您插入时间戳,但查询构建器不会。正如错误消息所示,它们不能为空。您有两种选择:

  1. 手动添加时间戳:

    DB::table('users')->insert([
        'name'      => 'Sample Name',
        'email'     => 'xxxx@gmail.com',
        'password'  => 'xxxxxx',
        'updated_at' => new \Carbon\Carbon,
        'created_at' => new \Carbon\Carbon
    ]);
    
  2. 或者使用您的用户模型为数据库设定种子,它将处理为您添加时间戳。

    User::create([
        'name'      => 'Sample Name',
        'email'     => 'xxxx@gmail.com',
        'password'  => 'xxxxxx'
    ]);