首页 > 数据库    日期:2026-06-11 / 浏览

物联网项目的时间大多时毫秒级的时间戳,在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

觉得上面的内容有用吗?快来点个赞吧!

点赞() 我要打赏

温馨提示 : 本站内容来自会员投稿以及互联网,所有源码及教程均为作者总结编辑,请大家在使用过程中提前做好备份,以免发生无法预知的错误,源码类教程请勿直接用于生产环境!

 可能感兴趣的文章