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 |
本文详细介绍如何在SQLServer中将Datetime类型的数据转换为UnixTimestamp。通过使用DATEADD和DATEDIFF函数,首先将本地时间调整为UTC时间,然后计算自1970年1月1日以来的秒数。
4636

被折叠的 条评论
为什么被折叠?



