MySQL中CURRENT_TIMESTAMP时间戳的使用详解
前言
最近在项目中发现一个小问题,数据被更改时,插入记录和更新记录的时间会被同步更新。设置的两个时间create_time、update_time,按照预期来讲,应该是创建记录的时候会同步更新create_time,update_time,而在更新记录的时候,只有update_time会被同步更新。但实际情况却是update记录时,两个time都会被同步更新。
在代码中并没有对时间进行显性的设置,对时间的维护是MySQL本身进行管理的,所以就查看了一下之前同事创建表时的SQL。
通过SQL语句可以看出,create_time 和 update_time 设置的都是 DEFAULT CURRENT_TIMESTAMP,不管是新创建的记录,还是更新原有的记录,只要是有触发的操作,这两个时间就会被同步修改。所以要达到预期的效果,就需要修改这里了。问题根源就是SQL语句这里的设置。
解决:
把update_time的 DEFAULT CURRENT_TIMESTAMP后面再加上条件限制 ON UPDATE CURRENT_TIMESTAMP。这样在更新记录时,只有更新时间被修改,创建时间就是最初创建记录的时间。
MySQL中的CURRENT_TIMESTAMP:
在创建时间字段的时候-----
① DEFAULT CURRENT_TIMESTAMP
表示当插入数据的时候,该字段默认值为当前时间
② ON UPDATE CURRENT_TIMESTAMP
表示每次更新这条数据的时候,该字段都会更新成当前时间
这两个操作是mysql数据库本身在维护,所以可以根据这个特性来生成【创建时间】和【更新时间】两个字段,且不需要代码来维护。
如下:
?1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 | CREATE TABLE `mytest` ( `id` bigint NOT NULL AUTO_INCREMENT, `comments` varchar (255) DEFAULT '' COMMENT '内容' , `create_time` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间' , `update_time` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间' ) ENGINE=InnoDB DEFAULT CHARSET=utf8; //如果想设置一个具体的默认时间可以这样: CREATE TABLE `mytest2` ( `id` bigint NOT NULL AUTO_INCREMENT, `comments` varchar (255) DEFAULT '' COMMENT '内容' , `create_time` timestamp DEFAULT '2020-12-12 12:12:12' COMMENT '创建时间' , `update_time` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间' , PRIMARY KEY (`id`) ) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8; |
补充:mysql自带的一些函数功能也是很强大的,这里整理了一下时间方面的
获取当前时间格式串:
?1 2 3 4 5 6 7 | #获取当前时间戳 current_timestamp() yyyy - mm - dd hh:ii:ss now() yyyy - mm - dd hh:ii:ss curdate() yyyy - mm - dd current_date() curtime() hh:ii:ss current_time() |
提取date各个字段
?1 2 3 4 5 | #提取date各个字段 date( 'yyyy-mm-dd hh:ii:ss' ) yyyy - mm - dd year( 'yyyy-mm-dd hh:ii:ss' ) yyyy month( 'yyyy-mm-dd hh:ii:ss' ) mm day( 'yyyy-mm-dd hh:ii:ss' ) dd |
提取time各个字段
?1 2 3 4 5 | #提取time各个字段 time( 'yyyy-mm-dd hh:ii:ss' ) hh:ii:ss hour( 'yyyy-mm-dd hh:ii:ss' ) hh minute( 'yyyy-mm-dd hh:ii:ss' ) ii second( 'yyyy-mm-dd hh:ii:ss' ) ss |
获取当前或者某一时间的unix时间戳
?1 2 3 4 | #unix时间戳1970-01-01以来的秒数 unix_timestamp() #同时还可以将某一时间格式串的秒数转化出来 unix_timestamp( 'yyyy-mm-dd hh:ii:ss' ) |
格式化时间串和格式化时间戳
?1 2 3 4 5 | #格式化时间串 date_format 与 time_format 为同一函数 输入为 date_format(now(), '%Y-%m-%d %T' ); time_format(now(), '%H:%i:%s' ); #格式化时间戳 将时间戳转化为时间格式串 from_unixtime(unix_timestamp(), "%Y-%m-%d %T" ) |
总结
到此这篇关于MySQL中CURRENT_TIMESTAMP时间戳使用的文章就介绍到这了,更多相关MySQL CURRENT_TIMESTAMP时间戳内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!
原文链接:https://blog.csdn.net/LZ15932161597/article/details/111060458
1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。