SQL时间戳


--临时表
CREATE TABLE #tmp (id INT,testtime timestamp)
--插入记录
INSERT INTO #tmp
        ( id )
VALUES  ( 1
          )
SELECT * FROM #tmp
--时间戳转int
SELECT CAST(testtime AS INT) FROM #tmp
SELECT CAST(CAST(testtime AS INT) AS TIMESTAMP) FROM #tmp
DROP TABLE #tmp
--datetime转unix时间戳
SELECT DATEDIFF(s, '19700101',GETDATE()) 
--unix时间戳转datetime
SELECT DATEADD(s, 1509099003 , '19700101')
--二进制时间
SELECT convert(timestamp,GETDATE())
--int 时间
SELECT CAST (convert(timestamp,GETDATE()) AS INT)
--datetime时间
SELECT DATEADD(s, CAST(convert(timestamp,GETDATE()) AS INT) , '19700101')
--数据库当前时间戳值
SELECT  @@DBTS

--普通时间  转  13 位时间戳
SELECT CONVERT(BIGINT,DATEDIFF(MI,'1970-01-01 00:00:00.000', GETUTCDATE())) * 60000 + DATEPART(S,GETUTCDATE()) * 1000 + DATEPART(MS, GETUTCDATE())

--13位时间戳 转 普通时间
SELECT DATEADD (MS ,CONVERT(BIGINT,1582687127323) % 60000 ,DATEADD(MI,CONVERT(BIGINT,1582687127323) / 60000,'1970-01-01 08:00:00.000'))

SELECT DATEDIFF(S,'1970-01-01 00:00:00', GETDATE()) 
--10位时间戳转换成普通时间
SELECT DATEADD(S,1557493321,'1970-01-01 00:00:00') 
SELECT 
CONVERT(BIGINT,DATEDIFF(MI,'1970-01-01 08:00:00.000', GETUTCDATE())) * 60000 + DATEPART(S,GETUTCDATE()) * 1000 + DATEPART(MS, GETUTCDATE())

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值