西部数码网站管理助手 数据库,山东省建设厅执业注册中心网站,贸易公司取什么名字,谷歌seo排名工具MySQL插入时间差八小时问题的解决方法 更新时间#xff1a;2019年12月15日 10:19:12 转载 作者#xff1a;lankeren
这篇文章主要给大家介绍了关于MySQL插入时间差八小时问题的解决方法#xff0c;文中通过示例代码介绍的非常详细#xff0c;对大家学习或者使用MySQL具…MySQL插入时间差八小时问题的解决方法 更新时间2019年12月15日 10:19:12 转载 作者lankeren
这篇文章主要给大家介绍了关于MySQL插入时间差八小时问题的解决方法文中通过示例代码介绍的非常详细对大家学习或者使用MySQL具有一定的参考学习价值需要的朋友们下面来一起学习学习吧 解决MySQL插入时间差八小时问题
一般 jdbc url中 需要添加几个参数 , 大多数博客给的教程都是 useSSLfalseuseUnicodetruecharacterEncodingUTF-8serverTimezoneUTC 这几个参数,
配置结果为: jdbc:mysql://localhost:3306/test?useUnicodetruecharacterEncodingUTF-8serverTimezoneUTC
对于解决时区问题以前我也是这么用的 serverTimezoneUTC 直到了今天踩到小坑了才知道这不是万能的.
首先正常插入一条记录
发现数据库的记录时间和本地的时间不太一样 第一种: 查看 mysql 中的时间
先在cmd中使用 mysql -u 用户名 -p 密码来登录mysql
输入select now();
查看MySQL时间 如果时间和你本地当前时间一致
说明mysql的时间没有问题, 问题就出现在java时间上
将jdbc url参数修改成 serverTimezoneAsia/Shanghai 试试.
第二种: 如果查询 mysql 时间和本地不一致,使用以下语句设置mysql时区 1 2 3 show variables like %time_zone%; //查询当前时区 set global time_zone8:00; //在标准时区上加8小时,即东8区时间 flush privileges; # 立即生效
最终测试效果 成功
总结
以上就是这篇文章的全部内容了希望本文的内容对大家的学习或者工作具有一定的参考学习价值谢谢大家对脚本之家的支持。 mysql set global time_zone 8:00; #修改mysql全局时区为北京时间即我们所在的东8区 set time_zone 8:00; #修改当前会话时区 flush privileges; #立即生效 Query OK, 0 rows affected
Query OK, 0 rows affected
Query OK, 0 rows affected mysql mysql show variables like %time_zone%; -------------------------- | Variable_name | Value | -------------------------- | system_time_zone | UTC | | time_zone | 08:00 | -------------------------- 2 rows in set
mysql mysql set system_time_zone 8:00; 这个不可修改 错误的命令 1238 - Variable system_time_zone is a read only variable mysql mysql mysql show variables like %time_zone%; -------------------------- | Variable_name | Value | -------------------------- | system_time_zone | UTC | | time_zone | 08:00 | -------------------------- 2 rows in set
mysql set global time_zone8:00; Query OK, 0 rows affected
mysql flush privileges; Query OK, 0 rows affected
mysql show variables like %time_zone%; -------------------------- | Variable_name | Value | -------------------------- | system_time_zone | UTC | | time_zone | 08:00 | -------------------------- 2 rows in set
mysql select now(); --------------------- | now() | --------------------- | 2020-06-05 18:42:22 | --------------------- 1 row in set
mysql show variables like %time_zone%; -------------------------- | Variable_name | Value | -------------------------- | system_time_zone | UTC | | time_zone | 08:00 | -------------------------- 2 rows in set
mysql