物联网项目的时间大多时毫秒级的时间戳,在SQL SERVER中转换为时间时会出现“将 expression 转换为数据类型 int 时出现算术溢出错误”
SELECT DATEADD(MILLISECOND, 1757304100073, '1970-01-01 00:00:00') 消息 8115,级别 16,状态 2,第 10 行 将 expression 转换为数据类型 int 时出现算术溢出错误。
原因分析
在 SQL Server 中出现这个错误是因为 DATEADD 函数的第二个参数(间隔数量)对于MILLISECOND 类型有范围限制,当数值过大时会超出 int 类型的最大值(2,147,483,647)。
时间戳 1757304100073 是一个毫秒级时间戳,远大于 int 类型的最大值,因此直接使用 MILLISECOND 参数会导致算术溢出。
解决办法:分两步转换
先处理秒,再处理毫秒。
先将毫秒级时间戳转换为秒级(除以 1000),再处理剩余的毫秒数:
DECLARE @timestamp BIGINT = 1757304100073;
-- 计算总秒数和剩余毫秒数
SELECT
DATEADD(MILLISECOND, @timestamp % 1000, -- 剩余毫秒数
DATEADD(SECOND, @timestamp / 1000, '1970-01-01 00:00:00') -- 秒级时间戳转换
)
--查询结果
2025-09-08 04:01:40.073













