大佬教程收集整理的这篇文章主要介绍了Sybase ASE 中的毫秒纪元转换,大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
我有一列毫秒格式的纪元。 我需要将它们转换为另一列日期时间,包括毫秒精度。
我尝试了各种组合(使用强制转换、转换等):
select dateadd(ss,1610309854301,'19700101')
我不断得到:
Arithmetic overflow during explicit conversion of BIGINT value '1610309854301'
对以前的帖子有一些评论,但没有对 ASE 起作用。
需要得到 1610309854301:这与另一列中的 this 相等。 2021 年 1 月 10 日星期日 20:17:34.301
这可以在 ASE 16.1 上的 sql 中完成吗?
谢谢!
运行一些快速测试,它看起来(在我看来)一些与日期相关的函数尚未更新以使用 bigint
数据类型(例如,dateadd()
的文档仅提及 {{1 }} 值作为参数)。
假设您有支持合同,我建议您向 SAP 开立案例,看看这是否是一个已知问题(以及是否计划/在未来版本中提供修复),或者是否有首选的解决方法。
一个简单的解决方法是将 int
值分成 2 个块 ... bigint
=> 秒数 ... /1000
=> 毫秒数 ... 和然后重新粘贴在一起以获得所需的结果,例如:
%1000
这会产生:
declare @ms bigint,@newdt datetime,-- limited to 3 millisec precision
@newdtb bigdatetime,-- supports microsecs so not limited to mod(3 msec)
@newdts varchar(30) -- collect strings to convert into (big)datetime
select @ms = 1610309854301
select @newdts = convert(varchar(30),dateadd(ss,@ms/1000,'19700101'),116) + '.' +
right('000'+convert(varchar(3),@ms % 1000),3 )
select @newdt = convert(datetime,@newdts)
select @newdtb = convert(bigdatetime,@newdts)
select @newdts,convert(varchar(30),@newdt,139),@newdtb,139)
go
注意:
------------------------------ ------------------------------ ------------------------------
Jan 10 2021 20:17:34.301 Jan 10 2021 20:17:34.300000 Jan 10 2021 20:17:34.301000
) 展示了 @newdt
对 ASE's
数据类型的限制(即 3 毫秒精度)datetime
不完美但...
dateadd(second,(number_of_millis / 1000),"01-01-1970")
例如dateadd(second,(1610309854301 / 1000),"01-01-1970")
如果使用秒,则会出现溢出错误。
或者如果作为选择的一部分使用
选择 dateadd(second,CONVERT(INT,(my_milli_second_column / 1000)),"01-01-1970")
以上是大佬教程为你收集整理的Sybase ASE 中的毫秒纪元转换全部内容,希望文章能够帮你解决Sybase ASE 中的毫秒纪元转换所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。