PostgreSQL
 sql >> Baza danych >  >> RDS >> PostgreSQL

Prześlij lub wyodrębnij znacznik czasu z UUID v1 w PostgreSQL

Przetestowałem to z uuid z mojej bazy danych i wydaje się, że działa bardzo dobrze, nawet bez niepodpisanych bigintów

CREATE FUNCTION uuid_timestamp(id uuid) RETURNS timestamptz AS $$
  select TIMESTAMP WITH TIME ZONE 'epoch' +
      (((('x' || lpad(split_part(id::text, '-', 1), 16, '0'))::bit(64)::bigint) +
      (('x' || lpad(split_part(id::text, '-', 2), 16, '0'))::bit(64)::bigint << 32) +
      ((('x' || lpad(split_part(id::text, '-', 3), 16, '0'))::bit(64)::bigint&4095) << 48) - 122192928000000000) / 10000000 ) * INTERVAL '1 second';    
$$ LANGUAGE SQL
  IMMUTABLE
  RETURNS NULL ON NULL INPUT;

uuid V1 utworzony przeze mnie w przyszłości 2099!

select uuid_timestamp('6d248400-65b7-1243-a57a-14109fec739e');
uuid_timestamp     
------------------------
 2099-08-01 11:30:00-07
(1 row)


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. sql do wyszukiwania najnowszego rekordu w grupie

  2. pg client.query() nie czeka na await

  3. Zapytanie o granty dla tabeli w postgres

  4. Importuj dane Postgres do RDS za pomocą S3 i aws_s3

  5. psql zwraca wartość / błąd zabija skrypt powłoki, który go wywołał?