服务器之家:专注于VPS、云服务器配置技术及软件下载分享
分类导航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|Access|数据库技术|

服务器之家 - 数据库 - Mysql - SQL处理时间戳时如何解决时区问题实例详解

SQL处理时间戳时如何解决时区问题实例详解

2022-08-30 14:52小白修炼晋级中 Mysql

时间戳时间不分东西南北、在地球的每一个角落都是相同的,下面这篇文章主要给大家介绍了关于SQL处理时间戳时如何解决时区问题的相关资料,文中通过实例代码介绍的非常详细,需要的朋友可以参考下

1.问题及解决办法

(1)问题:由于存储的时间戳是时间戳为GMT(格林尼治标准时间),以秒储存,但由于需要获取的是北京时间,存在时区问题。如何获取北京时区的时间日期?

(2)通过上网查找了解决办法,有一堆办法,有说连接时设置地区,都很复杂,本人没成功。尝试成功过的方法如下:

①方法一:在查询前设置时区,输入“set time_zone='+08:00';”

但这个方法存在弊端,不是非常通用,比如需要用python调用数据库查询时会报错。

②方法二:直接用公式将北京时区的时差相加,公式为:

?
1
(timestamp+8*3600)

说明:timestamp为时间戳,可为数字串也可为存在时间戳的字段。3600为一小时的秒数。该方法可以非常通用。

2.时区差相加公式的实例

(1)将时间戳转为小时(0-24小时)。其中timestamp为时间戳。

?
1
2
3
4
查询语句
select [column(s),]
(timestamp+8*3600)%86400/3600 as hour
[from table]

说明:时间戳是以秒8*3600表示北京时区的时差,86400=24*3600表示1天的秒数,“(timestamp+8*3600)%86400”中“%”取余数,余数则为当天时间点的秒数。3600是一小时的秒数,用当天时间点的秒数除以3600表示小时。

补充:SQL 关于时区的处理案例

设置时间偏移:SWITCHOFFSET(StopageStartTime,'+08:00')

时间转换:CONVERT(VARCHAR(19),SWITCHOFFSET(StopageStartTime,'+08:00'),121)

?
1
2
3
4
5
6
SELECT CONVERT(VARCHAR(19),SWITCHOFFSET(StopageStartTime,'+08:00'),121) AS StopageStartTime,
       CONVERT(VARCHAR(19),SWITCHOFFSET(StopageEndTime,'+08:00'),121) AS StopageEndTime,StopageType,AccidentReason_Preventive
                           ,EquipmentCode
                           FROM dbo.EquipmentDetection_Item
                           WHERE
                            CONVERT(VARCHAR(19),SWITCHOFFSET(StopageStartTime,'+08:00'),121)>=@startTime

总结

到此这篇关于SQL处理时间戳时如何解决时区问题的文章就介绍到这了,更多相关SQL解决时区问题内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!

原文链接:https://blog.csdn.net/weixin_50853979/article/details/124879563

延伸 · 阅读

精彩推荐