关于MySQL存入的时间和取出时间不一致的解决
场景:代码运行在Linux-A上,new Date() 生成的时间比当前时间早13个小时,导致存入数据库内的时间也早13个小时,但前台读取展示出来的时间又是正常的。在数据库直接select now()测试出来的时间也是比当前时间早13个小时。
分析:
问题一:Linux-B上的MySQL数据库内的时间设置有问题
问题二:Linux-A上代码new Date()出来的时间有问题
--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
遇到这样一个问题,Mysql的时区,没有设置,默认是时区是0,在java代码中对应的字段类型是TimeStamp,mysql字段类型也是TimeStamp
项目A
代码中获取到的时间 是正确的。
写到数据库的时间也是对的。
从数据库读取出来时间是正确的
项目B
代码中获取的时间是对的
写到数据库的时间,慢8小时
从数据库读取出来时间,却是正确的。(也就是说比数据库中的时间快8小时)
原因:
经过不断的尝试,探索终于发现时mysql-connector-java的版本问题,项目A使用的版本是5.1.41,项目B使用的8.0.11。写入数据时,8.0这个版本会自动根据,传入时间的时区和mysql的时区,自动把时间进行调整
服务器的mysql版本是5,如果服务器的mysql版本是8,则项目不能使用5版本的mysql-connector-java库。
查看mysql当前时间和时区
select CURTIME()或者select now()也行

show variables like "%time_zone%";
显示

time_zone说明mysql使用system的时区,system_time_zone说明system使用UTC时区

UTC时区比中国慢8小时这也就解释了数据库时间的由来
数据库中:

实际界面显示的:

关于MySQL存入的时间和取出时间不一致的解决的更多相关文章
- Linux/CentOS下的CST和UTC时间的区别以及不一致的解决方法
		
今天被我遇到了,相差八小时,,,tzselect过了都不行,还得用ntupdate核一下. 网上找的,备不时之需要. ~~~~~~~~~~~~~~~~ 1.在linux中,用date查看时间的时候显示 ...
 - kubernetes构建时容器的时间与宿主机不一致的解决方法
		
kubernetes默认使用docker容器部署的应用,会出现时间与主机不一致的情况 容器时间与主机差8个小时:主机的与容器的/etc/localtime不一致 解决方法:挂载主机的/etc/loca ...
 - 解决Mysql连接池被关闭 ,hibernate尝试连接不能连接的问题。 (默认mysql连接池可以访问的时间为8小时,如果超过8小时没有连接,mysql会自动关闭连接池。系统发布第二天访问链接关闭问题。
		
解决Mysql连接池被关闭 ,hibernate尝试连接不能连接的问题. (默认MySQL连接池可以访问的时间为8小时,如果超过8小时没有连接,mysql会自动关闭连接池. 所以系统发布第二天访问会 ...
 - 项目中 mysql中的内容关于上架时间和下架时间
		
隐藏左边导航 在mysql中,是存放的10位的时间截,在后台添加时,时间的格式是:'Y-m-d H:i',没有秒的 字段 字段名称 字段类型 是否为空 默认值 备注 publish_up int(11 ...
 - 怎样在mybatis里向mysql中插入毫秒数的时间?
		
由于业务场景需求,需要记录精准的时间,但是呢,又不要想使用int类型来存储时间,因为这样的可读性比较差了. 怎样在mybatis中向数据库插入毫秒级别的时间呢? 首先,先来看看怎样向数据库中插入毫秒时 ...
 - mysql中TIMESTAMP设置默认时间为当前时间
		
在我们保存数据进入到数据库中时多半会使用像php之类的脚本来获取一个时间保存到mysql中,其实在mysql可以直接使用TIMESTAMP 数据类型来实现默认类型了,下面一起来看看. 很多时候,为 ...
 - mysql的五种日期和时间类型【转载】
		
[mysql的五种日期和时间类型] mysql(5.5)所支持的日期时间类型有:DATETIME. TIMESTAMP.DATE.TIME.YEAR. 几种类型比较如下: 日期时间类型 占用空间 日期 ...
 - MySQL的五种日期和时间类型
		
MySQl中有多种表示日期和时间的数据类型.其中YEAR表示年份,DATE表示日期,TIME表示时间,DATETIME和TIMESTAMP表示日期和实践.它们的对比如下:YEAR ,字节数 ...
 - MYSQL查看数据表最后更新时间
		
MYSQL查看数据表最后更新时间 - 拨云见日 - CSDN博客 https://blog.csdn.net/warnerwu/article/details/73352774 mysql> S ...
 
随机推荐
- sql中 设置区分大小写
			
CI 指定不区分大小写,CS 指定区分大小写alter table 表名 alter column 字段 nvarchar(100) collate chinese_prc_cs_as --区分大小写 ...
 - ArcGIS for JavaScript 关于路径开发的一些记录(二)
			
又是高度集中开发路径模块的一天.真希望自己以后都可以如此的专注和高效(虽然知道很难一直都保持这样的状态,我会坚持的~哈哈哈) 言归正传,今天开发了途径点的功能和改进了些相关起点.终点的代码.先说一下我 ...
 - 一:JavaWeb和Tomcat的安装
			
1.Java Web 是java技术用来解决相关web互联网领域的技术总和. 2.Servlet是Java Servlet的简称,称为小服务程序或服务器连接器,用Java编写的服务器端程序 3.JSP ...
 - 在Windows Server 2012中打开传统的磁盘管理界面
			
在“运行”中输入diskmgmt.msc即可
 - JVM知识(一):基础原理
			
学过java知识和技术人,都应该听说过jvm,jvm一直是java知识里面晋级阶段的重要部分,如果想要在java技术领域更深入一步,jvm是必须需要明白的知识点. 本篇来讲解jvm的基础原理,先来熟悉 ...
 - selenium&phantom实战--获取代理数据
			
获取快代理网站的数据 注意: #!/usr/bin/env python # _*_ coding: utf-8 _*_ # __author__ ='kong' # 导入模块 from seleni ...
 - Oracle EBS 系统仅存在英文的环境
			
系统管理员 应用服务器 adadmin 编译
 - C++易混淆概念
			
1. 引用和指针有什么区别? 本质:一个是别名,一个是地址1. 指针可以在运行时改变其所指向的值,引用一旦和某个对象绑定就不再改变2. 引用没有const, 指针有const 3. 从内存上看,指针会 ...
 - .net通用类型转换方法
			
由于数据类型多,要按照逐个类型写一个类型转换的方法的话一是代码量多,显得累赘. using System; using System.ComponentModel; using System.Glob ...
 - [控件] LabelView
			
LabelView 此LabelView是用来将Label显示在固定的View上的,需要计算Label的高度与宽度. 源码: NSString+StringHeight.h 与 NSString+St ...