Duda acerca de la búsqueda por índice

From: Daymel Bonne Solís <dbonne(at)uci(dot)cu>
To: pgsql-es <pgsql-es-ayuda(at)postgresql(dot)org>
Subject: Duda acerca de la búsqueda por índice
Date: 2012-02-25 22:28:44
Message-ID: 1330208924.21290.12.camel@bonne-notebook
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-es-ayuda

Hola

Tengo una duda de cuando postgres realiza una búsqueda por índice.

test=# \d foo
Tabla «public.foo»
Columna | Tipo | Modificadores
---------+---------+---------------
unique1 | integer |
unique2 | integer |
Índices:
"fooi" btree (unique1, unique2)

Si realizo una búsqueda filtrando por la columna unique2 realiza una
búsqueda secuencial.

test=# explain select * from foo where unique2 in (1,2,3);
QUERY PLAN
-----------------------------------------------------
Seq Scan on foo (cost=0.00..182.50 rows=3 width=8)
Filter: (unique2 = ANY ('{1,2,3}'::integer[]))
(2 filas)

Sin embargo si filtro por la columna unique1 la búsqueda se realiza por
índice.

test=# explain select * from foo where unique1 in (1,2,3);
QUERY PLAN
----------------------------------------------------------------------
Index Only Scan using fooi on foo (cost=0.00..20.32 rows=3 width=8)
Index Cond: (unique1 = ANY ('{1,2,3}'::integer[]))
(2 filas)

¿Porqué ambas búsquedas no realizan utilizando el índice?

Saludos.

Fin a la injusticia, LIBERTAD AHORA A NUESTROS CINCO COMPATRIOTAS QUE SE ENCUENTRAN INJUSTAMENTE EN PRISIONES DE LOS EEUU!
http://www.antiterroristas.cu
http://justiciaparaloscinco.wordpress.com

Responses

Browse pgsql-es-ayuda by date

  From Date Subject
Next Message Eduardo Arenas C. 2012-02-26 12:15:31 pgstartup.log pesa 12GB
Previous Message Alvaro Herrera 2012-02-24 20:54:10 Re: error