Re: postgres 7.1.3: why does the query plan ignore indexes?

From: Tom Lane <tgl(at)sss(dot)pgh(dot)pa(dot)us>
To: Marco Vezzoli <marco(dot)vezzoli(at)st(dot)com>
Cc: sql <pgsql-sql(at)postgresql(dot)org>
Subject: Re: postgres 7.1.3: why does the query plan ignore indexes?
Date: 2003-08-19 13:26:29
Message-ID: 27563.1061299589@sss.pgh.pa.us
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-sql

Marco Vezzoli <marco(dot)vezzoli(at)st(dot)com> writes:
> ewsweb_test=> \d measures_product
> Index "measures_product"
> Attribute | Type
> ------------+----------
> product_id | smallint
^^^^^^^^

> ewsweb_test=> explain select zero_yield, gross from measures where
> product_id=29 and date between '2003-03-12' and '2003-08-14';
^^^^^^^^^^^^^

"29" is taken as an integer (int4). To get an indexscan on an int2
column, you need to explicitly cast it to int2:
product_id = 29::smallint
or you can put it in quotes and let the parser figure out the right
type:
product_id = '29'

Yes, we'd like to make this better, but there are surprisingly many
pitfalls in tinkering with the assignment of datatypes to constants...

regards, tom lane

PS: you could also consider whether it's really saving you any space to
store product_id as a smallint instead of int. Because of alignment
considerations, it very possibly isn't.

In response to

Responses

Browse pgsql-sql by date

  From Date Subject
Next Message Marco Vezzoli 2003-08-19 13:41:01 Re: postgres 7.1.3: why does the query plan ignore indexes?
Previous Message Rado Petrik 2003-08-19 13:02:24 Query problem