Mysql
 sql >> Datenbank >  >> RDS >> Mysql

Wie wandelt man das Hexadezimal in varchar(datetime) um?

Das sieht aus wie der SQL Server datetime Format. Intern wird dies als 2 Ganzzahlen gespeichert, wobei die ersten 4 Bytes die Tage seit dem 1. Januar 1900 und das 2. die Anzahl der Ticks seit Mitternacht sind (jeder Tick ist 1/300 Sekunde).

Wenn Sie dies in MySQL verwenden müssen, können Sie dies tun

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

Rückgabe

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

(Danke an Ted Hopp für die Lösung beim Splitten der Binärdaten)