共计 2275 个字符,预计需要花费 6 分钟才能阅读完成。
导读 | 这篇文章主要给大家介绍了关于 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 数据库本身在维护,所以可以根据这个特性来生成【创建时间】和【更新时间】两个字段,且不需要代码来维护。
如下:
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; |
获取当前时间格式串:
# 获取当前时间戳 | |
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 各个字段
# 提取 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 各个字段
# 提取 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 时间戳
#unix 时间戳 1970-01-01 以来的秒数 | |
unix_timestamp() | |
#同时还可以将某一时间格式串的秒数转化出来 | |
unix_timestamp('yyyy-mm-dd hh:ii:ss') |
格式化时间串和格式化时间戳
# 格式化时间串 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 时间戳使用的文章就介绍到这了。
