由于MySQL目前字段的默認(rèn)值不支持函數(shù),所以以create_time datetime default now() 的形式設(shè)置默認(rèn)值是不可能的。代替的方案是使用TIMESTAMP類型代替DATETIME類型炭序。
TIMESTAMP列類型自動(dòng)地用當(dāng)前的日期和時(shí)間標(biāo)記INSERT或UPDATE的操作瘫辩。如果有多個(gè)TIMESTAMP列烦秩,只有第一個(gè)自動(dòng)更新味悄。
自動(dòng)更新第一個(gè)TIMESTAMP列在下列任何條件下發(fā)生:
- 列值沒有明確地在一個(gè)INSERT或LOAD DATA INFILE語句中指定。
- 列值沒有明確地在一個(gè)UPDATE語句中指定且另外一些的列改變值坪创。(注意一個(gè)UPDATE設(shè)置一個(gè)列為它已經(jīng)有的值炕婶,這將不引起TIMESTAMP列被更新,因?yàn)槿绻阍O(shè)置一個(gè)列為它當(dāng)前的值莱预,MySQL為了效率而忽略更改柠掂。)
- 你明確地設(shè)定TIMESTAMP列為NULL.
- 除第一個(gè)以外的TIMESTAMP列也可以設(shè)置到當(dāng)前的日期和時(shí)間,只要將列設(shè)為NULL锁施,或NOW()陪踩。
所以把日期類型 選擇成timestamp 允許空就可以了
CREATE TABLE test (
uname varchar(50) NOT NULL,
updatetime timestamp NULL DEFAULTCURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
如果要在navicat下操作的話杖们,將字段設(shè)置為timestamp悉抵,然后默認(rèn)值寫上CURRENT_TIMESTAMP即可