sql >> Database >  >> RDS >> Mysql

hoe de hexadecimale naar varchar (datetime) te casten?

Dat lijkt op de SQL Server datetime formaat. Intern wordt dit opgeslagen als 2 gehele getallen, waarbij de eerste 4 bytes de dagen zijn sinds 1 januari 1900 en de 2e het aantal tikken sinds middernacht (elke tik is 1/300 van een seconde).

Als u dit in MySQL moet gebruiken, kunt u

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

Retourneren

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

(Met dank aan Ted Hopp voor de oplossing bij het splitsen van de binaire gegevens)



  1. Toegangsmenu maken met Tree View Control

  2. SQL-query voor het ophalen van gegevens van de afgelopen 3 maanden

  3. SQL ORDER BY:De 5 do's en don'ts om gegevens als een professional te sorteren

  4. Fix Error "ORA-01790:expressie moet hetzelfde datatype hebben als de corresponderende expressie"