PostgreSQL
 sql >> Database >  >> RDS >> PostgreSQL

Prestazioni del tipo UUID PostgreSQL

Avevamo una tabella con circa 30.000 righe che (per uno specifico motivo architettonico non correlato) aveva gli UUID archiviati in un campo di testo e indicizzati. Ho notato che la query perf era più lenta di quanto mi sarei aspettato. Ho creato una nuova colonna UUID, copiata nella chiave primaria uuid del testo e confrontata di seguito. 2,652 ms contro 0,029 ms. Una bella differenza!

 -- With text index
    QUERY PLAN
    Index Scan using tmptable_pkey on tmptable (cost=0.41..1024.34 rows=1 width=1797) (actual time=0.183..2.632 rows=1 loops=1)
      Index Cond: (primarykey = '755ad490-9a34-4c9f-8027-45fa37632b04'::text)
    Planning time: 0.121 ms
    Execution time: 2.652 ms

    -- With a uuid index 
    QUERY PLAN
    Index Scan using idx_tmptable on tmptable (cost=0.29..2.51 rows=1 width=1797) (actual time=0.012..0.013 rows=1 loops=1)
      Index Cond: (uuidkey = '755ad490-9a34-4c9f-8027-45fa37632b04'::uuid)
    Planning time: 0.109 ms
    Execution time: 0.029 ms