SQL Server 时间日期(datatime)和时间戳(unix_timestamp)相互转换

场 景

  最近接到一波机器心跳数据,存回了SQL Server,竟然是时间戳(unix_timestamp),如表1,那这展示出来也不知道是啥时候呀?于是转呗,奇怪,SQL Server还没有自带的函数,这就尴尬了。

表1 时间戳样例
最后一次心跳时间
1959214075
1927747569
1927684923

实 现

  某个时间点A时间戳(unix_timestamp)就是一个从1970-01-01 00:00:00到时间点A的相隔的秒数,所以算法就出来了,注意:这里的点A1970-01-01 00:00:00都是UTC时间,UTC时间和北京时间相差8个小时,所以如果你的时间戳是北京时间生成的,就应该是你的时间点相对于1970-01-01 08:00:00相差的秒数

  实现如下:

--时间戳转换成普通时间
SELECT DATEADD(S,1959214075,'1970-01-01 08:00:00')               

--普通时间转换成时间戳
SELECT DATEDIFF(S,'1970-01-01 08:00:00', GETDATE())       
  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

╭⌒若隐_RowYet——大数据

谢谢小哥哥,小姐姐的巨款

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

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

打赏作者

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

抵扣说明:

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

余额充值