mysql时间格式和Java时间格式的对应方式

 更新时间:2023年08月29日 08:46:44   作者:紫金小飞侠  
这篇文章主要介绍了mysql时间格式和Java时间格式的对应方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教

在 MySQL 中有两种存储时间的数据类型 DATETIME 和 TIMESTAMP ,它们在数据库实际应用中,各有各的优势和劣势。

以下将详细详解两个数据类型的区别,以及用实战案例说明它们的使用场景。

一. DATETIME 和 TIMESTAMP 的相同点

两个数据类型存储时间的格式一致。均为 YYYY-MM-DD HH:MM:SS

两个数据类型都包含「日期」和「时间」部分。

两个数据类型都可以存储微秒的小数秒(秒后6位小数秒)

二. DATETIME 和 TIMESTAMP 的区别

1.表示范围

  • DATETIME:1000-01-01 00:00:00.000000 到 9999-12-31 23:59:59.999999
  • TIMESTAMP:‘1970-01-01 00:00:01.000000’ UTC 到 ‘2038-01-09 03:14:07.999999’ UTC

2.空间占用

  • TIMESTAMP:占 4 个字节(小数秒+3 个字节)
  • DATETIME:在 MySQL 5.6.4 之前,占 8 个字节 ,之后版本,占 5 个字节。(小数秒+3 个字节)

3. 存入时间是否会自动转换?

  • TIMESTAMP:TIMESTAMP 的值是从「当前时间」转换成 UTC 时间,或者反过来转换。
  • DATETIME:不会做任何转换,也不会检测时区,你给什么数据,它存什么数据。

4.使用 now() 存储当前时间时

保存的实际值,是否与当前计算机时间一致?

  • TIMESTAMP:可能不一致。存储值会被转换成 UTC 时间值再存入数据库。
  • DATETIME:与当前时间是一致的。

5.如果存入的是 NULL 时,两个类型如何存储?

  • TIMESTAMP:会自动存储当前时间( now() )。
  • DATETIME:不会自动存储当前时间,会直接存入 NULL 值。

sql

CREATE TABLE `task_lock` (
  `id` bigint NOT NULL AUTO_INCREMENT,
  `task_name` varchar(255) NOT NULL,
  `lock_state` varchar(255) NOT NULL,
  `update_time` datetime DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=12 DEFAULT CHARSET=utf8mb3;

mybatis

    <insert id="save" parameterType="com.example.test1.model.TaskLock">
        insert into task_lock(task_name,lock_state,update_time) values(#{taskName},#{lockState},#{updateTime})
    </insert>

java

@Data
@AllArgsConstructor
@NoArgsConstructor
@Builder
public class TaskLock {
    private Integer id;
    private String taskName;
    private String lockState;
    private Date updateTime;
}
    @Autowired
    TaskLockMapper taskLockMapper;
    @Test
    public void InsetTest() {
        System.out.println(taskLockMapper);
        SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
        String currentSimpleDateFormat = simpleDateFormat.format(new Date());
       TaskLock taskLock = TaskLock.builder()
               .lockState("locked")
               .taskName("123")
               .updateTime(new Date())
               .build();
       int result = taskLockMapper.save(taskLock);
       System.out.println("result:"+result);
    }

在这里插入图片描述

总结

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

相关文章

  • MySQL用limit方式实现分页的实例方法

    MySQL用limit方式实现分页的实例方法

    在本篇文章中小编给大家整理了一篇关于MySQL用limit方式实现分页的实例方法,有需要的朋友们可以参考学习下。
    2020-01-01
  • mysql 多个字段实现逗号拼接

    mysql 多个字段实现逗号拼接

    在MySQL数据库中,有时候我们需要将多个字段的值连接在一起,本文主要介绍了mysql 多个字段实现逗号拼接,具有一定的参考价值,感兴趣的可以了解一下
    2024-01-01
  • MySQL 的CASE WHEN 语句使用说明

    MySQL 的CASE WHEN 语句使用说明

    本文介绍下,在mysql数据库中,有关case when语句的用法,介绍了case when语句的基础知识,并提供了相关实例,供大家学习参考,有需要的朋友不要错过
    2011-10-10
  • MySQL中使用正则表达式详情

    MySQL中使用正则表达式详情

    这牌你文章主要给大家分享的是MySQL中使用正则表达式详情,MySQL中支持正则表达式匹配,在复杂的过滤条件中,可以考虑使用正则表达式。使用正则表达式需要掌握一些正则表达式的语法和指令,下面来看看文章的详细内容介绍吧,希望对你有所帮助
    2021-11-11
  • mysql查询锁表方式

    mysql查询锁表方式

    在MySQL中,查询锁表可以通过多个命令实现,如show engine innodb status、show processlist等,用以检测和解决表锁问题,首先通过show engine innodb status查看锁表情况,接着利用show processlist找出长时间占用的SQL语句
    2024-09-09
  • MySQL中InnoDB存储引擎的锁的基本使用教程

    MySQL中InnoDB存储引擎的锁的基本使用教程

    这篇文章主要介绍了MySQL中InnoDB存储引擎的锁的基本概念,是MySQL入门学习中的基础知识,需要的朋友可以参考下
    2015-11-11
  • MySQL安装提示配置信息已损坏请联系技术人员

    MySQL安装提示配置信息已损坏请联系技术人员

    为了重新安装MySql,看别人的博客说在注册表中搜索mysql,全部删除。再安装时提示配置信息已损坏,遇到这个问题怎么处理呢,下面小编给大家带来了详细解决方法,感兴趣的朋友一起看看吧
    2023-01-01
  • Mysql中Json相关的函数使用

    Mysql中Json相关的函数使用

    本文主要介绍了Mysql当中Json相关的函数使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-06-06
  • JDBC连接mysql处理中文时乱码解决办法详解

    JDBC连接mysql处理中文时乱码解决办法详解

    这篇文章主要介绍了JDBC连接mysql处理中文时乱码解决办法详解的相关资料,希望通过本文能帮助到大家,需要的朋友可以参考下
    2017-10-10
  • MySQL表分区的几种实现

    MySQL表分区的几种实现

    本文主要介绍了MySQL表分区的几种实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-08-08

最新评论