Mysql
 sql >> Base de Dados >  >> RDS >> Mysql

como converter o hexadecimal para varchar (datetime)?


Isso se parece com o SQL Server datetime formato. Internamente, isso é armazenado como 2 inteiros, com os primeiros 4 bytes sendo os dias desde 1º de janeiro de 1900 e o 2º sendo o número de tiques desde a meia-noite (cada tique sendo 1/300 de segundo).

Se você precisar usar isso no MySQL, você pode fazer
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

Devoluções
converted_datetime
--------------------------
2006-11-17 00:00:00
2011-02-09 18:52:34.286667

(Agradecimentos a Ted Hopp pela a solução na divisão dos dados binários)