sql >> Databáze >  >> RDS >> Mysql

jak přenést hexadecimální číslo na varchar (datetime)?

Vypadá to jako datetime SQL Serveru formát. Interně je to uloženo jako 2 celá čísla, přičemž první 4 bajty jsou dny od 1. ledna 1900 a 2. jsou počet tiků od půlnoci (každý tik je 1/300 sekundy).

Pokud to potřebujete použít v MySQL, můžete to udělat

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

Vrátí

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

(Díky Tedovi Hoppovi za řešení při rozdělování binárních dat)



  1. Jak používat klauzuli Execute Immediate with INTO v databázi Oracle

  2. 3 způsoby, jak zjistit, zda je sloupec vypočítaným sloupcem na serveru SQL

  3. Postgres - VYTVOŘTE TABULKU Z VÝBĚRU

  4. Zpracování chyb na úrovni absolventa