sql >> Databáze >  >> RDS >> PostgreSQL

Odesílejte nebo extrahujte časové razítko z v1 UUID v PostgreSQL

Testoval jsem to s uuid z mé databáze a zdá se, že to funguje velmi dobře, dokonce i bez nepodepsaných bigintů

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, který jsem vytvořil v budoucnosti v roce 2099!

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


  1. TimescaleDB:efektivně vyberte poslední řádek

  2. Použití aliasu pro server localhost v MySQL

  3. získání tří záznamů v sestupném pořadí každé kategorie pomocí codeigniter

  4. Jak získat včerejší datum v T-SQL