SQLServer中Datetime类型转换为UnixTimes
2019-01-22 本文已影响0人
菜鸟飞不动
SQLServer中Datetime类型转换为UnixTimestamp
Datetime类型转换为UnixTimestamp
SELECT DATEDIFF(SECOND,{d '1970-01-01'}, DateAdd(s,DateDiff(s, getdate(),getutcdate()), [CreationTime])) 'utctimestamp',[CreationTime]
FROM [TABLE]
步骤说明
1. 将CreateTime字段转换为UTC
DATEADD() 函数在日期中添加或减去指定的时间间隔。
定义和用法
DATEADD() 函数在日期中添加或减去指定的时间间隔。
语法
DATEADD(datepart,number,date)
date 参数是合法的日期表达式。number 是您希望添加的间隔数;对于未来的时间,此数是正数,对于过去的时间,此数是负数。
datepart 参数可以是下列的值:
datepart | 缩写 |
---|---|
年 | yy, yyyy |
季度 | qq, q |
月 | mm, m |
年中的日 | dy, y |
日 | dd, d |
周 | wk, ww |
星期 | dw, w |
小时 | hh |
分钟 | mi, n |
秒 | ss, s |
毫秒 | ms |
微妙 | mcs |
纳秒 | ns |
select DateAdd(s,DateDiff(s, getdate(),getutcdate()), [CreateTime])
2. 计算UnixTimestamp
DATEDIFF(SECOND,{d '1970-01-01'}, DateAdd(s,DateDiff(s, getdate(),getutcdate()), [CreationTime]))
定义和用法
DATEDIFF() 函数返回两个日期之间的时间。
##### 语法
DATEDIFF(datepart,startdate,enddate)
startdate 和 enddate 参数是合法的日期表达式。
datepart 参数可以是下列的值:
datepart | 缩写 |
---|---|
年 | yy, yyyy |
季度 | qq, q |
月 | mm, m |
年中的日 | dy, y |
日 | dd, d |
周 | wk, ww |
星期 | dw, w |
小时 | hh |
分钟 | mi, n |
秒 | ss, s |
毫秒 | ms |
微妙 | mcs |
纳秒 | ns |