sql >> Databasteknik >  >> RDS >> Mysql

hur gjuter man hexadecimalen till varchar(datetime)?

Det ser ut som SQL Server datetime formatera. Internt lagras detta som 2 heltal där de första 4 byten är dagarna sedan 1 jan 1900 och den andra är antalet tick sedan midnatt (varje tick är 1/300 av en sekund).

Om du behöver använda detta i MySQL kan du göra

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

Retur

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

(Tack till Ted Hopp för lösningen vid uppdelning av binära data)



  1. Hur överför man pandas DataFrame till PostgreSQL-tabellen?

  2. LocalDB-distribution på klientdator

  3. Hur man returnerar alla inaktiverade främmande nyckelbegränsningar i SQL Server (T-SQL-exempel)

  4. Hur får man Insert id i MSSQL i PHP?