浅谈Mybatis+mysql 存储Date类型的坑
场景:
把一个时间字符串转成Date,存进Mysql。时间天数会比实际时间少1天,也可能是小时少了13-14小时
Mysql的时区是CST(使用语句:showVARIABLESLIKE'%time_zone%';查)
先放总结:
修改方法:
1.修改数据库时区
2.在jdbc.url里加后缀&serverTimezone=GMT%2B8
3.代码里设置时区,给SimpleDateFormat.setTimeZone(...)
例外:newDate()可以直接存为正确时间,其他的不行。比如我试过,把newDate用sdf转个2次,然后就错误了
贴一下测试的一下渣码
//1.newDate()直接存数据库则是正确的日期结果:√190626,数据库存储正常 //Datenow=newDate(); //2,newDate()用simpleDateFormat转化为字符串再转为Date。结果:×少1天190625 //Datenow1=newDate(); //StringtempStr=yyMMddFormatter.format(now1); //StringtempStrDate=tempStr.split("")[0];//会加上00:00:00 //Datedate=yyMMddFormatter.parse(tempStrDate); //3.配置文件加上&serverTimezone=GMT%2B8,√正确 //4.设置中国标准时区UTC+8结果:√ //SimpleDateFormatsdf=newSimpleDateFormat("yyMMdd"); //设置时区:中国标准时ChinaStandardTimeUTC+08:00使用GMT+8东8区,结果:?使用默认时区setTimeZone(TimeZone.getDefault); //sdf.setTimeZone(TimeZone.getTimeZone("UTC+8")); //System.out.println(sdf.getTimeZone().toString()); //Datedate=sdf.parse(liftMaxDt); //System.out.println(sdf.getTimeZone().toString()); //System.out.println(date); // //DatetargetDate=newDate(date.getTime()); //System.out.println("------------------"); //System.out.println(targetDate); //5.测试毫秒数newDate(ms);但是要先使用sdf转入参结果:×问题就在于SimpleDateFormat会混乱时区 //SimpleDateFormatsdf=newSimpleDateFormat("yyMMdd"); //Datedate=sdf.parse(liftMaxDt); //DatetargetDate=newDate(date.getTime()); //System.out.println("使用sdf转换date,在newDate(date.getTime())-----------"); //System.out.println(targetDate); //使用LocalDate.结果:×还是少一天 DateTimeFormatterdf=DateTimeFormatter.ofPattern("yyMMdd"); LocalDateldt=LocalDate.parse(liftMaxDt,df); System.out.println("String类型的时间转成LocalDateTime:"+ldt); //LocalDate转LocalDateTime LocalDateTimelll=LocalDateTime.of(ldt,LocalTime.of(0,0,0)); ZoneIdzone=ZoneId.systemDefault(); Instantinstant=lll.atZone(zone).toInstant(); DatetargetDate=Date.from(instant); //将对象里时间属性设置为String,数据库里仍然用Date,用数据库的时间函数转化
最后,还是采用的数据库为timestamp类型,用mysql的时间函数进行转换,保证时间为数据库时间
补充知识:mybatis解决java中的date类型存入oracle数据库之后不显示时分秒
实体类中类型为java.util.Date
privateDateupdate_date;
数据库中对应字段的类型为Date
不显示时分秒的情况:
Mapping文件中对应字段的jdbcType为DATE类型
如果显示时分秒的话,只需要将Mapping文件中对应字段的类型改为TIMESTAMP即可.
以上这篇浅谈Mybatis+mysql存储Date类型的坑就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持毛票票。
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。