Mysql
这种现象其实是正常的,因为es默认存储时间的格式是UTC时间,我们一般用的是UTC+8
存入Es后应该是在原来的基础上(UTC+8)-8=UTC 存入到Es后就变成我们看到的样子了
首先知道几个时间名词:
(1)GMT:格林威治标准时间
(2)UTC:世界协调时间
(3)DST:夏日节约时间
(4)CST:中国标准时间
其中GMT时间可以近似认为和UTC时间是相等的,但从精度上来说UTC时间更精确。其误差值必须保持在0.9秒以内
CST= GMT + 8 =UTC + 8
从上面可以看出来中国的时间是等于UTC时间+8小时,es默认存储时间的格式是UTC时间,如果我们查询es然后获取时间日期默认的数据,会发现跟当前的时间差8个小时,对于es来说这其实是正常的
而我们数据库的存储一般使用GMT+8(中国标准时间)文章来源:https://www.toymoban.com/news/detail-787382.html
可以尝试的解决方案:
1、将时间写入ES中string类型字段;
2、将时间以时间戳的形式存入ES中long类型字段;
3、ES默认是UTC时间,将时间+8h后存入ES中date类型字段;
4、写入时间数据时,指定时区,eg:“time”: “2016-07-15T12:58:17.136+0800” //东八区时间文章来源地址https://www.toymoban.com/news/detail-787382.html
到了这里,关于数据存入es 时间差了8个小时的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!