一尘不染

如何将十六进制转换为varchar(datetime)?

mysql

我的日期时间导出为“ CAST(0x0000987C00000000 AS
DateTime)”,但是当我想将其恢复为日期时间时,它是一个NULL值。我如何才能再次将它保存到日期时间。


阅读 339

收藏
2020-05-17

共1个答案

一尘不染

看起来像SQL Server
datetime格式。在内部,该值存储为2个整数,前4个字节是自1900年1月1日以来的天数,第二个是自午夜以来的滴答数(每个滴答是1/300秒)。

如果您需要在MySQL中使用它,可以

SELECT 
      CAST(
          '1900-01-01 00:00:00' + 
          INTERVAL CAST(CONV(substr(HEX(BinaryData),1,8), 16, 10)  AS SIGNED) DAY +
          INTERVAL CAST(CONV(substr(HEX(BinaryData),9,8), 16, 10)  AS SIGNED)* 10000/3 MICROSECOND
      AS DATETIME) AS converted_datetime
FROM
(
SELECT 0x0000987C00000000 AS BinaryData
UNION ALL
SELECT 0x00009E85013711EE AS BinaryData
) d

退货

converted_datetime
--------------------------
2006-11-17 00:00:00
2011-02-09 18:52:34.286667

(感谢Ted Hopp提供拆分二进制数据的解决方案

2020-05-17