浅谈Mybatis+mysql 存储Date类型的坑
作者:水平则静 发布时间:2024-01-17 19:13:14
标签: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即可.
来源:https://blog.csdn.net/qq_35911589/article/details/93759855


猜你喜欢
- 开门见山,直接使用 skimage 库为图像添加高斯噪声是很简单的:import skimageorigin = skimage.io.im
- 又发一个js版幻灯片,接口比较少,但功能和外观都还不错的,可自定义切换时间:)method: adRotator.initialize(容器
- 本文实例为大家分享了python学生管理系统开发的具体代码,供大家参考,具体内容如下学生管理系统(基础版)#定义一个函数,显示可以使用的功能
- 当遇到一个模板标签(template tag)时,模板解析器就会把标签包含的内容,以及模板解析器自己作为参数调用一个python函数。 这个
- 最近使用vscode进行前端编程,遇到一些问题网上说明的不是很明显,故记录一下 1.开vscode使用CTRL+`或者点击查看到集成终端打开
- numpy 中 的random模块有多个函数用于生成不同类型的随机数,常见的有 uniform、rand、random、randint、ra
- 在《数据库原理》里面,对聚簇索引的解释是:聚簇索引的顺序就是数据的物理存储顺序,而对非聚簇索引的解释是:索引顺序与数据物理排列顺序无关。正式
- 数据的安全性策略: 数据的生考虑应基于数据的重要性。如果数据不是很重要,那么数据的安全性策略可以稍稍放松一些。然而,如果数据很重要,那么应该
- 一、读写excel数据利用pandas可以很方便的读写excel数据1.1 读:data_in = pd.read_excel('M
- Math.random()Math.random()是JavaScript默认提供的生成随机数的方法。该方法返回一个0到1之间的浮点数,其值
- 本文实例为大家分享了mysql5.7安装图文教程供大家参考,具体内容如下1.在官网下载解压缩版2.解压后配置默认文件新建个my.ini(可以
- 日志作为项目开发和运行中必备组件,python提供了内置的logging模块来完成这个工作;借助 TimedRotatingFileHand
- layui的table的自定义模板需要用到{{}},但是和Django的{{}}冲突了,layui的{{}}失效了解决方法:从Django
- 前言在了解了REST farmwork封装的视图类之后,我对python的面向对象有了更深刻的理解。Django RESR framewor
- 现在同类型的网站数不胜数,网站的功能或服务日趋同质化,大的方面看不出什么差别,差别就体现在细节上。“窥斑见豹”,细节成为网站最有力的表现形式
- 在向大家详细介绍Linux mysql之前,首先让大家了解下Linux mysql,然后全面介绍Linux mysql,希望对大家有用。1.
- 本文实例为大家分享了tensorflow如何批量读取图片的具体代码,供大家参考,具体内容如下代码:import tensorflow as
- 一、修改密码1.1 创建修改密码控制器运行命令php artisan make:controller Auth/PasswordContro
- 一些很实用且必用的js小脚本代码:脚本1:进入页面后自动播放音乐或其它声音文件<embed src="音乐地址&q
- 为了防止再次被攻击,做个验证码过滤程序是必要的。我在网上找了一些资料,觉得用别人做好的代码总是很不爽,自己做麻又不会写复杂的代码,特别是生成