sql >> Databasteknik >  >> RDS >> PostgreSQL

Kasta eller extrahera tidsstämpel från v1 UUID i PostgreSQL

Jag har testat detta med uuid från min databas och det verkar fungera väldigt bra, även utan de osignerade bigints

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;

en V1 uuid som jag skapade i framtiden 2099!

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


  1. Vad är det enklaste sättet att göra en kolumn LÄSENDAST i Oracle?

  2. Hur man kontrollerar värdena för NLS-parametrarna i Oracle Database

  3. Få bara datum utan tid i Oracle

  4. SQL-fel version 5.5.15