专注WEB开发 分享经验,沉淀知识

mysql 多个timestamp类型字段的默认值设置问题

 作者:chenxing  时间:2017-08-15 21:15  阅读:1666  评论:

对于多个tiemstamp类型的字段只能有一个自动实现自动更新(或插入)当前时间。

先看创建mysql的错误:'Incorrect table definition; there can be only one TIMESTAMP column with CURRENT_TIMESTAMP in DEFAULT or ON UPDATE clause',英文不错的朋友就能马上找到原因,此信息大致意思是‘不能有多个timestamp类型的字段同时设置默认值或者 on update为current_timestamp ’。

timestamp类型字段

由上可知我们在拥有多个timestamp类型字段默认值设置时就需要规避这些错误,如果没有提前看这些特性,这个问题是非常容易犯的错误,我本人就踩很多次坑。

比如下面的错误定义:


create table test(
    created timestamp default current_timestamp comment '创建时间',
    updated timestamp default 0 on update current_timestamp comment '更新时间'
)

从逻辑上出发以上的语句天衣无缝,而且非常方便,一个是创建时插入当前时间,一个是更新是插入当前时间。但你执行的时候就会报开头的那个错误,一个表中只能有一个字段设置为current_timestamp,反正mysql就是这么规定的。

正确的做法应该是这样:


create table test(
    created timestamp default 0 comment '创建时间',
    updated timestamp default 0 on update current_timestamp comment '更新时间'
)

至于created值的获取只好由外部的程序代劳了。对于多个tiemstamp类型的字段只能有一个自动实现自动更新(或插入)当前时间。

总之,一个表有且只有一个字段能设置默认值为current_timestamp。

另外,补充几个相关知识:

//插入和更新操作自动更新时间
time TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP
//插入操作自动更新时间
time TIMESTAMP DEFAULT CURRENT_TIMESTAMP
//更新操作自动更新时间
time TIMESTAMP DEFAULT 0 ON UPDATE CURRENT_TIMESTAMP

以上就是今天的要讲的几个知识点,希望对大家有所帮助。

除特别注明外,本网站所有文章均为作者原创。 或分享自己的编程经验,或探讨工作中的问题,或聊以人生趣事。 转载请注明出处来自 https://www.qiusuoweb.com/67.html

发布评论

 提交评论
有人回复时邮件通知我

 评论(0)

站长头像
chenxing(PHP攻城狮)

运营天数

总访问量

文章数量

-

-

-

交流群:157451741

新浪微博:草莽兴

 近期文章

一年时间又回到这里

 2019-07-27 16:54  155

PHP字符串转数组的三种场景

 2018-05-05 01:32  201

PHP如何遍历字符串?

 2018-05-04 00:56  1319

api接口常见的安全问题和解决方案

 2018-05-03 23:20  988

 最新评论

 lisheng: 05月09日 19:26
兴哥牛B加油哈兴哥成功的道路上你又进了一步 哈哈
来源: 一年时间又回到这里
 心态炸裂: 03月24日 10:54
No3.blindcomfirm 多了一个l,望改正!!!
来源: 微信小程序获取input值的总结
 666666: 11月08日 13:49
66666
来源: 一年时间又回到这里
 花花草草: 10月14日 14:58
tp5不是已经提前开了吗
来源: _SESSION变量未定义?
 疯了: 10月10日 13:40
你好呀,我使用docker构建的 把整个项目给了777 并把runtime的所有者给了nginx php的运行者还是报错
来源: thinkphp5的mkdir() Permission denied问题探讨
 mesecretme: 09月30日 15:30
有个问题,有没有发现用redis保存session的话,session清空redis的key还没过期,会依然保留的,这是值变成空了
来源: php项目redis实现session共享案例