mysql设置值timestamp获取当前时间并自动更新方式

 更新时间:2023年07月24日 09:58:21   作者:ITzhongzi  
这篇文章主要介绍了mysql设置值timestamp获取当前时间并自动更新方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

需求描述:现需要数据库中一个字段来记录当前记录的最近修改时间或者创建时间,并自动更新维护。

timestamp类型的使用

示例如下:

创建一个数据库,并指定 uptime为 timestamp类型

create  table test(
	tid int primary key auto_increment,
	uptime timestamp,
	hobby varchar(20)
);

插入一条数据

insert into test (tid,uptime,hobby) values(null,null,null);

查看数据库数据

在这里插入图片描述

我们看到数据插入成功,但是uptime字段显示为 null

我们再插入一条数据,如下:

insert into test (tid,uptime,hobby) values(null,current_timestamp,null);

查看数据库数据如下:

在这里插入图片描述

我们看到第二条数据插入成功了,并且时间为 当前插入的时间

下面我们更新一下字段看 时间是否会自动维护

update test set hobby='篮球'  where tid < 4;

我们看效果

在这里插入图片描述

时间并没有自动更新,还是我们插入的时间,并不是修改的时间。

我们首先手动更新一下时间:

update test set uptime = current_timestamp where tid < 10;

效果如图:

在这里插入图片描述

当我们设置timestamp类型为current_timestamp时,系统会自动获取当前修改或者创建时间,但是不糊自动维护。

那么问题来了?

如何让timestamp类型自动维护

1.我们重新传建一个是数据库

create table test2(
	pid int primary key  auto_increment,
	uptime timestamp null default current_timestamp on update current_timestamp,
	hobby varchar(30)
);

2.我们先看一下创建后的表结构:

show create table test2;

在这里插入图片描述

我们注意一下 uptime 字段,可以为空,默认时间为current_timestamp, on update curret_timestamp设置可以使记录发生改变的时候时间自动改变。

插入一条没有默认时间的数据数据

insert into test2 values(null,null,null);

查看表结构

在这里插入图片描述

我们可以看到当我们没有设置默认值的时候时间默认为null

我们再插入一条带默认时间的数据

insert into test2 values(null,current_timestamp,null);

如图:

在这里插入图片描述

我们可以看到 有两条数据,一条有默认时间一条没有。

下面我们修改一下 两条记录,看时间是否会自动维护

update test2 set hobby='篮球' where pid < 5;

大功告成~

在这里插入图片描述

我们可以看到时间字段 在 自动维护,之前默认值为空的时候,在修改记录之后也会自动将时间改为 修改时间。

最后的完善

我们已经可以做到 时间自动维护了,还有一个 小缺点,

就是在刚开始插入时间时,我们没有传入默认时间的话,初始值为null,只有我们修改这条记录的时候他才会自动记录时间。

完善方案:

在创建数据库的时候设置 uptime字段为 not null

create table test3(pid int primary key auto_increment,uptime timestamp not null default current_timestamp on update current_timestamp);

表结构如下:

在这里插入图片描述

这样我们就会在创建该记录时候强制传入一个时间,并在修改的时候自动维护。

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • 浅析MySQL的lru链表

    浅析MySQL的lru链表

    这篇文章主要介绍了MySQL lru链表的相关资料,帮助大家更好的理解和使用MySQL数据库,感兴趣的朋友可以了解下
    2020-11-11
  • MySQL查看表和清空表的常用命令总结

    MySQL查看表和清空表的常用命令总结

    这篇文章主要介绍了MySQL查看表和清空表的常用命令总结,是MySQL入门学习中的基础知识,需要的朋友可以参考下
    2015-11-11
  • mysql 5.7安装 MySQL 服务无法启动但是服务没有报告任何错误

    mysql 5.7安装 MySQL 服务无法启动但是服务没有报告任何错误

    这篇文章主要介绍了mysql 5.7安装 MySQL 服务无法启动但是服务没有报告任何错误的相关资料,需要的朋友可以参考下
    2017-04-04
  • Mysql逗号拼接字符串的关联查询以及统计问题

    Mysql逗号拼接字符串的关联查询以及统计问题

    有时为了数据库简洁,存放数据的时候,某一字段采用逗号隔开的形式进行存储,下面这篇文章主要给大家介绍了关于Mysql逗号拼接字符串的关联查询以及统计问题的相关资料,需要的朋友可以参考下
    2023-03-03
  • MySQL动态修改varchar长度的方法

    MySQL动态修改varchar长度的方法

    这篇文章主要介绍了MySQL动态修改varchar长度的方法的相关资料,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2016-07-07
  • MySQL内存使用之线程独享介绍

    MySQL内存使用之线程独享介绍

    这篇文章主要介绍了MySQL内存使用之线程独享介绍,线程独享内存主要用于各客户端连接线程存储各种操作的独享数据,如线程栈信息,分组排序操作,数据读写缓冲,结果集暂存等等,而且大多数可以通过相关参数来控制内存的使用量,需要的朋友可以参考下
    2014-12-12
  • VS2019连接mysql8.0数据库的教程图文详解

    VS2019连接mysql8.0数据库的教程图文详解

    这篇文章主要介绍了VS2019连接mysql8.0数据库的教程,本文通过图文并茂的形式给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-05-05
  • CentOS 7下使用rpm包安装mysql 5.7.18

    CentOS 7下使用rpm包安装mysql 5.7.18

    这篇文章主要为大家详细介绍了CentOS 7下使用rpm包安装mysql 5.7.18的教程,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-07-07
  • MySQL使用Replace操作时造成数据丢失的问题解决

    MySQL使用Replace操作时造成数据丢失的问题解决

    这篇文章主要给大家介绍了关于MySQL使用Replace操作时造成数据丢失问题的解决方法,文中通过示例代码介绍的非常详细,对大家学习或者使用MySQL具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-09-09
  • linux下利用Docker安装mysql的步骤

    linux下利用Docker安装mysql的步骤

    这篇文章主要给大家介绍了关于在linux下利用Docker安装mysql的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-12-12

最新评论