欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

淺談Mybatis+mysql 存儲Date類型的坑

 更新時(shí)間:2020年11月23日 17:27:50   作者:水平則靜  
這篇文章主要介紹了淺談Mybatis+mysql 存儲Date類型的坑,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧

場景:

把一個(gè)時(shí)間字符串轉(zhuǎn)成Date,存進(jìn)Mysql。時(shí)間天數(shù)會(huì)比實(shí)際時(shí)間少1天,也可能是小時(shí)少了13-14小時(shí)

Mysql的時(shí)區(qū)是CST(使用語句:show VARIABLES LIKE '%time_zone%'; 查)

先放總結(jié):

修改方法:

1. 修改數(shù)據(jù)庫時(shí)區(qū)

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

3. 代碼里設(shè)置時(shí)區(qū),給SimpleDateFormat.setTimeZone(...)

例外:new Date() 可以直接存為正確時(shí)間,其他的不行。比如我試過,把new Date用sdf轉(zhuǎn)個(gè)2次,然后就錯(cuò)誤了

貼一下測試的一下渣碼

// 1.new Date()直接存數(shù)據(jù)庫則是正確的日期 結(jié)果:√ 190626,數(shù)據(jù)庫存儲正常
//  Date now = new Date();
 
  // 2,new Date()用simpleDateFormat轉(zhuǎn)化為字符串再轉(zhuǎn)為Date。結(jié)果: × 少1天 190625
//  Date now1 = new Date();
//  String tempStr = yyMMddFormatter.format(now1);
//  String tempStrDate = tempStr.split(" ")[0];// 會(huì)加上00:00:00
//  Date date = yyMMddFormatter.parse(tempStrDate);
 
  // 3.配置文件加上&serverTimezone=GMT%2B8,√ 正確
 
  // 4. 設(shè)置中國標(biāo)準(zhǔn)時(shí)區(qū) UTC+8 結(jié)果:√
//  SimpleDateFormat sdf = new SimpleDateFormat("yyMMdd");
   // 設(shè)置時(shí)區(qū): 中國標(biāo)準(zhǔn)時(shí) China Standard Time UTC+08:00 使用GMT+8東8區(qū),結(jié)果:?使用默認(rèn)時(shí)區(qū)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. 測試毫秒數(shù) new Date(ms);但是要先使用sdf轉(zhuǎn)入?yún)?結(jié)果:× 問題就在于SimpleDateFormat會(huì)混亂時(shí)區(qū)
//  SimpleDateFormat sdf = new SimpleDateFormat("yyMMdd");
//  Date date = sdf.parse(liftMaxDt);
//  Date targetDate = new Date(date.getTime());
//  System.out.println("使用sdf轉(zhuǎn)換date,在new Date(date.getTime())-----------");
//  System.out.println(targetDate);
 
  // 使用LocalDate.結(jié)果: × 還是少一天
  DateTimeFormatter df = DateTimeFormatter.ofPattern("yyMMdd");
  LocalDate ldt = LocalDate.parse(liftMaxDt, df);
  System.out.println("String類型的時(shí)間轉(zhuǎn)成LocalDateTime:"+ldt);
  // LocalDate轉(zhuǎn)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);
 
  // 將對象里時(shí)間屬性設(shè)置為String,數(shù)據(jù)庫里仍然用Date,用數(shù)據(jù)庫的時(shí)間函數(shù)轉(zhuǎn)化

最后,還是采用的數(shù)據(jù)庫為timestamp類型,用mysql的時(shí)間函數(shù)進(jìn)行轉(zhuǎn)換,保證時(shí)間為數(shù)據(jù)庫時(shí)間

補(bǔ)充知識:mybatis解決java中的date類型存入oracle數(shù)據(jù)庫之后不顯示時(shí)分秒

實(shí)體類中類型為java.util.Date

private Date update_date;

數(shù)據(jù)庫中對應(yīng)字段的類型為Date

不顯示 時(shí)分秒 的情況:

Mapping文件中對應(yīng)字段的jdbcType為DATE類型

如果顯示時(shí)分秒的話,只需要將Mapping文件中對應(yīng)字段的類型改為TIMESTAMP即可.

以上這篇淺談Mybatis+mysql 存儲Date類型的坑就是小編分享給大家的全部內(nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • java解析任意層數(shù)json字符串的方法

    java解析任意層數(shù)json字符串的方法

    一個(gè)方法解析任意層數(shù)的json字符竄:使用正則表達(dá)式,遞歸算法,將jsonArray解析出后添加到List, JsonObject添加至Map
    2014-02-02
  • SpringBoot中swagger的使用

    SpringBoot中swagger的使用

    這篇文章主要介紹了SpringBoot中swagger的使用,文中有非常詳細(xì)的代碼示例,對正在學(xué)習(xí)swagger的小伙伴們有非常好的幫助,需要的朋友可以參考下
    2021-05-05
  • SSM框架整合之Spring+SpringMVC+MyBatis實(shí)踐步驟

    SSM框架整合之Spring+SpringMVC+MyBatis實(shí)踐步驟

    大家都知道Spring是一個(gè)輕量級的控制反轉(zhuǎn)(IoC)和面向切面(AOP)的容器框架,本文主要介紹三大框架的整合包含spring和mybatis的配置文件,還有spring-mvc的配置文件的詳細(xì)介紹,通過項(xiàng)目實(shí)踐步驟給大家詳細(xì)介紹,感興趣的朋友一起看看吧
    2021-06-06
  • 淺談一下Servlet的定義以及運(yùn)行原理

    淺談一下Servlet的定義以及運(yùn)行原理

    相信有很多剛?cè)胄械呐笥褧?huì)疑惑Servlet到底是個(gè)什么意思,那么這篇文章就來淺談一下到底什么是Servlet,以及Servlet的原理與如何寫一個(gè)Servlet,,需要的朋友可以參考下
    2023-03-03
  • Java日常練習(xí)題,每天進(jìn)步一點(diǎn)點(diǎn)(23)

    Java日常練習(xí)題,每天進(jìn)步一點(diǎn)點(diǎn)(23)

    下面小編就為大家?guī)硪黄狫ava基礎(chǔ)的幾道練習(xí)題(分享)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧,希望可以幫到你
    2021-07-07
  • 關(guān)于Java8中map()和flatMap()的一些事

    關(guān)于Java8中map()和flatMap()的一些事

    這篇文章主要給大家介紹了關(guān)于Java8中map()和flatMap()的一些事,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-10-10
  • java GUI實(shí)現(xiàn)加法計(jì)算器

    java GUI實(shí)現(xiàn)加法計(jì)算器

    這篇文章主要為大家詳細(xì)介紹了java GUI實(shí)現(xiàn)加法計(jì)算器,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-04-04
  • SpringBoot整合MyBatis的代碼詳解

    SpringBoot整合MyBatis的代碼詳解

    這篇文章主要介紹了SpringBoot整合MyBatis筆記記錄,大家需要注意在整合mybatis之前我們需要相對應(yīng)的導(dǎo)入相關(guān)依賴,首先需要在java的目錄和resources下創(chuàng)建mapper文件夾,對SpringBoot整合MyBatis的詳細(xì)過程感興趣的朋友一起看看吧
    2022-05-05
  • Java多線程中的ThreadPoolExecutor解讀

    Java多線程中的ThreadPoolExecutor解讀

    這篇文章主要介紹了Java多線程中的ThreadPoolExecutor解讀,線程池中的核心線程數(shù),當(dāng)提交一個(gè)任務(wù)時(shí),線程池創(chuàng)建一個(gè)新線程執(zhí)行任務(wù),直到當(dāng)前線程數(shù)等于corePoolSize;如果當(dāng)前線程數(shù)為corePoolSize,繼續(xù)提交的任務(wù)被保存到阻塞隊(duì)列中,等待被執(zhí)行,需要的朋友可以參考下
    2023-09-09
  • Spring Boot整合EhCache的步驟詳解

    Spring Boot整合EhCache的步驟詳解

    EhCache 是一個(gè)純Java的進(jìn)程內(nèi)緩存框架,具有快速、精干等特點(diǎn),是Hibernate中默認(rèn)CacheProvider。這篇文章主要介紹了Spring Boot整合EhCache的步驟詳解,需要的朋友可以參考下
    2020-02-02

最新評論