开发者社区> 问答> 正文

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

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

展开
收起
保持可爱mmm 2020-05-17 14:13:30 483 0
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提供的拆分二进制数据的解决方案)来源:stack overflow

    2020-05-17 14:18:52
    赞同 展开评论 打赏
问答排行榜
最热
最新

相关电子书

更多
搭建电商项目架构连接MySQL 立即下载
搭建4层电商项目架构,实战连接MySQL 立即下载
PolarDB MySQL引擎重磅功能及产品能力盛大发布 立即下载

相关镜像