日期时区转换问题--跨国业务
----------跨国业务怎么解决时区问题----------
最好的方案,就是所有接口级的时间参数的出参入参都以时间戳方式进行。所以的计算、排序查询、区间范围查询都用时间戳来解决就方便很多了,查询效率也高。
入参:前端把当前国家时区对应的字符串格式的时间转成时间戳后,再调用接口把时间戳存库。
出参:前端拿到接口数据后,再把时间戳转换成当前国家时区对应的字符串格式的时间,再展示给用户看。
-------------------Mysql的时间类型 timestamp------------
一、timestamp在mysql实际存的是时间戳。
我们看到的时间是可视化工具查的被mysql服务器转换出来的时间字符串,并且和mysql服务器设置的时区有关,不信你可以修改mysql时区试试.数据不变的情况,时间戳是不变的,你修改mysql服务器成不同的时区,你的navicat等可视化工具再次查询,会看到不一样的时间字符串.
查询和设置Mysql时区的命令见:https://www.cnblogs.com/blog-ice/p/10243963.html
二、时间精度存储问题剖析。
拿timestamp(3)和timestamp(6)举例,比如用的mybatis,我们在insert时是以Date类型转成timestamp,然后保存其时间戳。这里转换成timestamp就得看其位数设置了,如果是3位,就转换成毫秒级的时间戳,如果是6位,就转换成微秒级的时间戳。
看情况设置吧,在精度要求很高的情况下,如果设置不当,可能会丢失精度。