浅谈Mybatis+mysql 存储Date类型的坑

 更新时间:2020年11月23日 17:27:50   作者:水平则静  
这篇文章主要介绍了浅谈Mybatis+mysql 存储Date类型的坑,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧

场景:

把一个时间字符串转成Date,存进Mysql。时间天数会比实际时间少1天,也可能是小时少了13-14小时

Mysql的时区是CST(使用语句:show VARIABLES LIKE '%time_zone%'; 查)

先放总结:

修改方法:

1. 修改数据库时区

2. 在jdbc.url里加后缀 &serverTimezone=GMT%2B8

3. 代码里设置时区,给SimpleDateFormat.setTimeZone(...)

例外:new Date() 可以直接存为正确时间,其他的不行。比如我试过,把new Date用sdf转个2次,然后就错误了

贴一下测试的一下渣码

// 1.new Date()直接存数据库则是正确的日期 结果:√ 190626,数据库存储正常
//  Date now = new Date();
 
  // 2,new Date()用simpleDateFormat转化为字符串再转为Date。结果: × 少1天 190625
//  Date now1 = new Date();
//  String tempStr = yyMMddFormatter.format(now1);
//  String tempStrDate = tempStr.split(" ")[0];// 会加上00:00:00
//  Date date = yyMMddFormatter.parse(tempStrDate);
 
  // 3.配置文件加上&serverTimezone=GMT%2B8,√ 正确
 
  // 4. 设置中国标准时区 UTC+8 结果:√
//  SimpleDateFormat sdf = new SimpleDateFormat("yyMMdd");
   // 设置时区: 中国标准时 China Standard Time UTC+08:00 使用GMT+8东8区,结果:?使用默认时区setTimeZone(TimeZone.getDefault);
//  sdf.setTimeZone(TimeZone.getTimeZone("UTC+8"));
//  System.out.println(sdf.getTimeZone().toString());
//  Date date = sdf.parse(liftMaxDt);
//  System.out.println(sdf.getTimeZone().toString());
//  System.out.println(date);
//
//  Date targetDate = new Date(date.getTime());
//  System.out.println("------------------");
//  System.out.println(targetDate);
 
 
  // 5. 测试毫秒数 new Date(ms);但是要先使用sdf转入参 结果:× 问题就在于SimpleDateFormat会混乱时区
//  SimpleDateFormat sdf = new SimpleDateFormat("yyMMdd");
//  Date date = sdf.parse(liftMaxDt);
//  Date targetDate = new Date(date.getTime());
//  System.out.println("使用sdf转换date,在new Date(date.getTime())-----------");
//  System.out.println(targetDate);
 
  // 使用LocalDate.结果: × 还是少一天
  DateTimeFormatter df = DateTimeFormatter.ofPattern("yyMMdd");
  LocalDate ldt = LocalDate.parse(liftMaxDt, df);
  System.out.println("String类型的时间转成LocalDateTime:"+ldt);
  // LocalDate转LocalDateTime
  LocalDateTime lll = LocalDateTime.of(ldt, LocalTime.of(0,0,0));
  ZoneId zone = ZoneId.systemDefault();
  Instant instant = lll.atZone(zone).toInstant();
  Date targetDate = Date.from(instant);
 
  // 将对象里时间属性设置为String,数据库里仍然用Date,用数据库的时间函数转化

最后,还是采用的数据库为timestamp类型,用mysql的时间函数进行转换,保证时间为数据库时间

补充知识:mybatis解决java中的date类型存入oracle数据库之后不显示时分秒

实体类中类型为java.util.Date

private Date update_date;

数据库中对应字段的类型为Date

不显示 时分秒 的情况:

Mapping文件中对应字段的jdbcType为DATE类型

如果显示时分秒的话,只需要将Mapping文件中对应字段的类型改为TIMESTAMP即可.

以上这篇浅谈Mybatis+mysql 存储Date类型的坑就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • 深入java内存查看与分析详解

    深入java内存查看与分析详解

    本篇文章是对java内存查看进行了详细的分析介绍,需要的朋友参考下
    2013-05-05
  • 一文简介Java中BlockingQueue阻塞队列

    一文简介Java中BlockingQueue阻塞队列

    本文主要介绍了一文简介Java中BlockingQueue阻塞队列,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-06-06
  • 基于Java实现修改图片分辨率示例代码

    基于Java实现修改图片分辨率示例代码

    这篇文章主要介绍了一个可以修改图片分辨率的java工具类,文中的示例代码讲解详细,对学习JAVA有一定的帮助,感兴趣的小伙伴快来跟随小编一起学习吧
    2021-12-12
  • 使用Java visualVM监控远程JVM的流程分析

    使用Java visualVM监控远程JVM的流程分析

    我们经常需要对我们的开发的软件做各种测试, 软件对系统资源的使用情况更是不可少,JDK1.6开始自带的VisualVM就是不错的监控工具,本文给大家分享使用Java visualVM监控远程JVM的问题,感兴趣的朋友跟随小编一起看看吧
    2021-05-05
  • Java实现添加,读取和删除Excel图片的方法详解

    Java实现添加,读取和删除Excel图片的方法详解

    本文介绍在Java程序中如何添加图片到excel表格,以及如何读取、删除excel表格中已有的图片。文中的示例代码讲解详细,感兴趣的可以学习一下
    2022-05-05
  • Java中&&与?表达式结合时出现的坑

    Java中&&与?表达式结合时出现的坑

    这篇文章主要给大家介绍了关于Java中&&与?表达式结合时出现的坑的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-02-02
  • java子线程解决获取主线程的request对象问题

    java子线程解决获取主线程的request对象问题

    这篇文章主要介绍了java子线程解决获取主线程的request对象问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-08-08
  • SpringBoot使用Validation校验参数的详细过程

    SpringBoot使用Validation校验参数的详细过程

    这篇文章主要介绍了SpringBoot使用Validation校验参数,本文结合实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-09-09
  • Spring中@Conditional注解的用法

    Spring中@Conditional注解的用法

    这篇文章主要介绍了Spring中@Conditional注解的用法,@Conditional是Spring4新提供的注解,它的作用是按照一定的条件进行判断,满足条件给容器注册bean,需要的朋友可以参考下
    2024-01-01
  • Java线程同步机制_动力节点Java学院整理

    Java线程同步机制_动力节点Java学院整理

    在之前,已经学习到了线程的创建和状态控制,但是每个线程之间几乎都没有什么太大的联系。可是有的时候,可能存在多个线程多同一个数据进行操作,这样,可能就会引用各种奇怪的问题。现在就来学习多线程对数据访问的控制吧
    2017-05-05

最新评论