程序问答   发布时间:2022-05-31  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了Sybase ASE 中的毫秒纪元转换大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。

如何解决Sybase ASE 中的毫秒纪元转换?

开发过程中遇到Sybase ASE 中的毫秒纪元转换的问题如何解决?下面主要结合日常开发的经验,给出你关于Sybase ASE 中的毫秒纪元转换的解决方法建议,希望对你解决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 ) 展示了 @newdtASE'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,请注明来意。
标签: