SQLServer中将时间戳转换为时间格式

水深无声 2022-07-15 07:28 1595阅读 0赞

时间戳就是一个从1970-01-01 08:00:00到时间的相隔的秒数。所以只要把这个时间戳加上:1970-01-01 08:00:00这个时间就可以得到你想要的时间了:

select DATEADD(second,1268738429 + 8 * 60 * 60,’1970-01-01 00:00:00’)

注解:北京时间与GMT时间关系  

1.GMT是中央时区,北京在东8区,相差8个小时   

2.所以北京时间 = GMT时间 + 八小时

例如: SELECT DATEADD(s,1160701488 + 8 * 3600,’1970-01-01 00:00:00’) —时间戳转换成普通时间SELECT DATEADD(second,1160701488 + 8 * 3600,’1970-01-01 00:00:00’)

SELECT DATEDIFF(s,’1970-01-01 00:00:00’, ‘2006-10-13 09:04:48.000’) - 8 * 3600 —普通时间转换成时间戳

SELECT DATEDIFF(second,’1970-01-01 00:00:00’, ‘2006-10-13 09:04:48.000’) - 8 * 3600

本文博主遇到了如下的问题,所以修改了一下sql,做了类型转换:

问题:The conversion of the varchar value ‘1478516592689’ overflowed an int column 明显是varchar的值默认转为int的时候超出了界限,所以通过下面的sql把int转为了bigint: CONVERT(VARCHAR(20),DATEADD(SECOND,CAST(#{item.finish_time} as bigint)/1000+28800,’1970-01-01’),120)

将时间戳转换为普通日期类型

发表评论

表情:
评论列表 (有 0 条评论,1595人围观)

还没有评论,来说两句吧...

相关阅读