timestamp有两个属性,分别是CURRENT_TIMESTAMP 和ON UPDATE CURRENT_TIMESTAMP两种,使用情况分别如下:
- CURRENT_TIMESTAMP
当要向数据库执行insert操作时,如果有个timestamp字段属性设为 CURRENT_TIMESTAMP,则无论这个字段有木有set值都插入当前系统时间
- ON UPDATE CURRENT_TIMESTAMP
当执行update操作是,并且字段有ON UPDATE CURRENT_TIMESTAMP属性。则字段无论值有没有变化,他的值也会跟着更新为当前UPDATE操作时的时间。
若要取消timestamp的ON UPDATE CURRENT_TIMESTAMP属性可以执行如下两种命令:
//下面这种会有默认值,即默认值不允许为空,默认为当前时间。
alter table tableName change oldcolumnNmae newcolumnName TIMESTAMP DEFAULT CURRENT_TIMESTAMP
//下面的允许为空,即默认值为NULL
alter table tableName change oldcolumnNmae newcolumnName TIMESTAMP NULL