Mysql
 sql >> Baza danych >  >> RDS >> Mysql

jak rzutować szesnastkowy na varchar(datetime)?

To wygląda jak SQL Server datetime format. Wewnętrznie to jest przechowywane jako 2 liczby całkowite, przy czym pierwsze 4 bajty to dni od 1 stycznia 1900, a 2 to liczba tików od północy (każdy tik trwa 1/300 sekundy).

Jeśli potrzebujesz tego użyć w MySQL, możesz zrobić

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

Zwroty

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

(Podziękowania dla Teda Hoppa za rozwiązanie w dzieleniu danych binarnych)



  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Jak wysłać e-mail z MySQL 5.1?

  2. Czy w MySQL istnieje alternatywa dla TOP?

  3. Usuń wiersze sql, w których identyfikatory nie pasują do innej tabeli

  4. Pobieranie nieprzetworzonego ciągu zapytania SQL z przygotowanych instrukcji PDO

  5. Dynamicznie twórz obiekt PHP na podstawie napisu