日期时区转换问题--跨国业务

----------跨国业务怎么解决时区问题----------

最好的方案,就是所有接口级的时间参数的出参入参都以时间戳方式进行。所以的计算、排序查询、区间范围查询都用时间戳来解决就方便很多了,查询效率也高。
入参:前端把当前国家时区对应的字符串格式的时间转成时间戳后,再调用接口把时间戳存库。
出参:前端拿到接口数据后,再把时间戳转换成当前国家时区对应的字符串格式的时间,再展示给用户看。

-------------------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位,就转换成微秒级的时间戳。
看情况设置吧,在精度要求很高的情况下,如果设置不当,可能会丢失精度。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

java_爱吃肉

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值