将默认(当前日期时间)设置为表列 - CodeIgniter 3迁移

时间:2018-02-14 13:35:47

标签: codeigniter codeigniter-3

我有这个迁移:

public function up(){
    $this->dbforge->add_field([
        'id'=>['type'=>'int', 'unique'=>true, 'unsigned'=>true,'auto_increment'=>true],
        'email'=>['type'=>'varchar', 'constraint'=>200, 'null'=>true],
        'password'=>['type'=>'varchar', 'constraint'=>250],
        'created_at'=>['type'=>'datetime', 'default' => 'CURRENT_TIMESTAMP'],
    ]);
    $this->dbforge->add_key('id', TRUE);
    $this->dbforge->create_table('users', TRUE);
}

我正在尝试使用默认值 - 当前日期时间设置列created_at的表。 我正在使用'default' => 'CURRENT_TIMESTAMP',但我收到此错误:

  

' created_at'的默认值无效....   NOT NULL,created_at datetime NOT NULL DEFAULT' CURRENT_TIMESTAMP',

我将CodeIgniter 3MySQL一起使用。

1 个答案:

答案 0 :(得分:4)

这对我有用,并且在文档中有效

将字符串作为字段传递如果您确切地知道想要字段如何 创建后,您可以使用以下命令将字符串传递到字段定义中: add_field()

$ this-> dbforge-> add_field(“ label varchar(100)NOT NULL DEFAULT '默认标签'“);

注意: 将原始字符串作为字段传递后,不能再通过add_key()调用 这些字段。

`$this->dbforge->add_field(
  array(
    'nombre' => 
      array(
        'type' => 'VARCHAR',
        'constraint' => '150',
      ),
    'paterno' => 
      array(
        'type' => 'VARCHAR',
        'constraint' => '80',
      ),
    'materno' => 
      array(
        'type' => 'VARCHAR',
        'constraint' => '80',
      ),
    'correo' => 
      array(
        'type' => 'varchar',
        'constraint' => '150',
        'unique'=> TRUE,
    ),
    'username' => 
      array(
        'type' => 'varchar',
        'constraint' => '80',
    ),
    'genero' => 
      array(
        'type' => 'varchar',
        'constraint' => '30',
    ),
    'pass' => 
      array(
        'type' => 'varchar',
        'constraint' => '255',
    ),
    'direccion' => 
      array(
        'type' => 'varchar',
        'constraint' => '200',
    ),
    'telefono' => 
      array(
        'type' => 'varchar',
        'constraint' => '30',
    ),
    'celular' => 
      array(
        'type' => 'varchar',
        'constraint' => '30',
    ),
    'created_at datetime default current_timestamp',
    'updated_at datetime default current_timestamp on update current_timestamp',
    'status' => 
      array(
        'type' => 'tinyint',
        'constraint' => '1',
    ),
  )
);`