Spring Boot(Mybatis,Mysql) 查询时间类型的数据比数据库里的记录慢8个小时

lingxue 2018-10-25 16:35:38 阅读 5802 评论 0 喜欢 1
SpringBoot 时区 Mybatis Mysql 

    最近用Spring Boot + Mybatis +Mysql 搭建的一个项目,突然发现页面查询出来的记录,时间比较数据库里保存的那条记录慢8个小时,用sql 语句到数据库里查询出来是正常的,一开始没仔细调试,以为是Mybatis数据层返回时就错了,试了网上说的几种解决方案,都没用:

    1  链接mysql的url上 添加参数 &serverTimezone=UTC, 或者增加&serverTimezone=Asia/Shanghai 

    2  进入mysql 查看时区是什么 :

        > show variables like "%time_zone%";


        如果时区不对,修改  :

        > set global time_zone = '+8:00';  ##修改mysql全局时区为北京时间,即我们所在的东8区        
        > set time_zone = '+8:00';  ##修改当前会话时区        
        > flush privileges;  #立即生效

 

     3 仔细调试,发现其实是Controller 在返回json 数据到浏览器的时候出错了,试过网上说的,修改配置文件,也没有用:

        spring:
            jackson:
                time-zone: GMT+8

 

       4 然后试了一下这种方式:

    import org.springframework.boot.SpringApplication;
    import org.springframework.boot.autoconfigure.SpringBootApplication;
 
    import javax.annotation.PostConstruct;
    import java.util.TimeZone;
 
    @SpringBootApplication
    public class SpringBootStudyApplication {
 
     //设置时区 相差8小时
     @PostConstruct
     void started() {
      TimeZone.setDefault(TimeZone.getTimeZone("UTC"));
     }
 
     public static void main(String[] args) {
      SpringApplication.run(SpringBootStudyApplication.class, args);
     }
    }

说明:

1、spring-boot中对于@RestController或者@Controller+@ResponseBody注解的接口方法的返回值默认是Json格式,

所以当对于date类型的数据,在返回浏览器端是会被spring-boot默认的Jackson框架转换,而Jackson框架默认的时区GMT(相对于中国是少了8小时)。

但是不知道为什么我这个项目再配置文件加上jackson的时区配置不起作用。


2、@PostContruct是spring框架的注解,在方法上加该注解会在项目启动的时候执行该方法,也可以理解为在spring容器初始化的时候执行该方法。 

 

3、TimeZone.setDefault(TimeZone.getTimeZone("UTC")); 用来修改整个java应用程序的时区,当jvm默认的时区不是中国时间时,可以这样手动修改。


     加上以上代码后,重启,刷新页面,时间确实显示对了,本来以为彻底解决了,但是发现刷新多几遍,时间有时候显示是对的,有时候显示还是慢8个小时,原因我也不清楚。而且会导致我在获取系统当前时间的时候,慢8八个小时。

    

    后面发现我的实体类的时间属性,都用@JsonFormat 格式化了:@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss"),@JsonFormat 是jackson的注解,查资料发现这个注解可以加上时区的设置:

@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss",timezone="GMT+8")
 private Date createTime;

    删掉启动类里 TimeZone.setDefault(TimeZone.getTimeZone("UTC"));的代码,然后在所有实体类的时间属性上,加上上面的注解代码,就彻底解决了。

支持@用户名回复

×  

:bowtie: :smile: :laughing: :blush: :smiley: :relaxed: :smirk: :heart_eyes: :kissing_heart: :kissing_closed_eyes: :flushed: :relieved: :satisfied: :grin: :wink: :stuck_out_tongue_winking_eye: :stuck_out_tongue_closed_eyes: :grinning: :kissing: :kissing_smiling_eyes: :stuck_out_tongue: :sleeping: :worried: :frowning: :anguished: :open_mouth: :grimacing: :confused: :hushed: :expressionless: :unamused: :sweat_smile: :sweat: :weary: :pensive: :disappointed: :confounded: :fearful: :cold_sweat: :persevere: :cry: :sob: :joy: :astonished: :scream: :neckbeard: :tired_face: :angry: :rage: :triumph: :sleepy: :yum: :mask: :sunglasses: :dizzy_face: :imp: :smiling_imp: :neutral_face: :no_mouth: :innocent: :alien: :yellow_heart: :blue_heart: :purple_heart: :heart: :green_heart: :broken_heart: :heartbeat: :heartpulse: :two_hearts: :revolving_hearts: :cupid: :sparkling_heart: :sparkles: :star: :star2: :dizzy: :boom: :collision: :anger: :exclamation: :question: :grey_exclamation: :grey_question: :zzz: :dash: :sweat_drops: :notes: :musical_note: :fire: :hankey: :poop: :shit: :+1: :thumbsup: :-1: :thumbsdown: :ok_hand: :punch: :facepunch: :fist: :v: :wave: :hand: :open_hands: :point_up: :point_down: :point_left: :point_right: :raised_hands: :pray: :point_up_2: :clap: :muscle: :metal: :walking: :runner: :running: :couple: :family: :two_men_holding_hands: :two_women_holding_hands: :dancer: :dancers: :ok_woman: :no_good: :information_desk_person: :raised_hand: :bride_with_veil: :person_with_pouting_face: :person_frowning: :bow: :couplekiss: :couple_with_heart: :massage: :haircut: :nail_care: :boy: :girl: :woman: :man: :baby: :older_woman: :older_man: :person_with_blond_hair: :man_with_gua_pi_mao: :man_with_turban: :construction_worker: :cop: :angel: :princess: :smiley_cat: :smile_cat: :heart_eyes_cat: :kissing_cat: :smirk_cat: :scream_cat: :crying_cat_face: :joy_cat: :pouting_cat: :japanese_ogre: :japanese_goblin: :see_no_evil: :hear_no_evil: :speak_no_evil: :guardsman: :skull: :feet: :lips: :kiss: :droplet: :ear: :eyes: :nose: :tongue: :love_letter: :bust_in_silhouette: :busts_in_silhouette: :speech_balloon: :thought_balloon:

共0条评论

相似文章

  • 顶部
  • 关灯
  • 留言
  • 点赞