sql >> データベース >  >> RDS >> Mysql

16進数をvarchar(datetime)にキャストする方法は?

    これは、SQLServerのdatetimeのように見えます フォーマット。内部的には、これは2つの整数として格納され、最初の4バイトは1900年1月1日からの日数であり、2番目は深夜からのティック数です(各ティックは1/300秒です)。

    MySQLでこれを使用する必要がある場合は、次のことができます

    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
    

    返品

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

    ソリューションを提供してくれたTedHoppに感謝します バイナリデータの分割)



    1. SQL FOREIGN KEY CONSTRAINT:初心者のための究極の簡単なガイド

    2. SQL Serverでsys.sql_dependenciesを使用しないでください(非推奨)

    3. ON句のMySQL不明列

    4. Postgresタイムスタンプクエリ範囲を最適化する