Re: Why the planner is not using the INDEX .

From: Stephan Szabo <sszabo(at)megazone(dot)bigpanda(dot)com>
To: David Gagnon <dgagnon(at)siunik(dot)com>
Cc: pgsql-performance(at)postgresql(dot)org
Subject: Re: Why the planner is not using the INDEX .
Date: 2005-07-04 20:27:41
Message-ID: 20050704132446.O14579@megazone.bigpanda.com
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-performance

On Mon, 4 Jul 2005, David Gagnon wrote:

> If you can just help my understanding the choice of the planner.
>
> Here is the Query:
> explain analyse SELECT IRNUM FROM IR
> INNER JOIN IT ON IT.ITIRNUM = ANY ('{1000, 2000}') AND
> IT.ITYPNUM = 'M' AND IR.IRYPNUM = IT.ITYPNUM AND IR.IRNUM = IT.ITIRNUM
> WHERE IRNUM = ANY ('{1000, 2000}') and IRYPNUM = 'M'
>
> Here is the Query plan:
>
> QUERY PLAN
>
> Hash Join (cost=1142.47..5581.75 rows=87 width=4) (actual
> time=125.000..203.000 rows=2 loops=1)
> Hash Cond: ("outer".itirnum = "inner".irnum)
> -> Seq Scan on it (cost=0.00..3093.45 rows=31646 width=9) (actual
> time=0.000..78.000 rows=2 loops=1)
> Filter: ((itirnum = ANY ('{1000,2000}'::integer[])) AND
> ((itypnum)::text = 'M'::text))
>
> -> Hash (cost=1142.09..1142.09 rows=151 width=37) (actual
> time=125.000..125.000 rows=0 loops=1)
> -> Index Scan using ir_pk on ir (cost=0.00..1142.09 rows=151
> width=37) (actual time=0.000..125.000 rows=2 loops=1)
> Index Cond: ((irypnum)::text = 'M'::text)
> Filter: (irnum = ANY ('{1000,2000}'::integer[]))
> Total runtime: 203.000 ms

> I don't understand why the planner do a Seq Scan (Seq Scan on table
> IT ..) instead of passing by the followin index:
> ALTER TABLE IT ADD CONSTRAINT IT_IR_FK foreign key (ITYPNUM,ITIRNUM)
> references IR (IRYPNUM, IRNUM) ON UPDATE CASCADE;

That doesn't create an index on IT. Primary keys (and unique constraints)
create indexes, but not foreign keys. Did you also create an index on
those fields?

Also it looks like it's way overestimating the number of rows that
condition would succeed for. You might consider raising the statistics
targets on those columns and reanalyzing.

In response to

Responses

Browse pgsql-performance by date

  From Date Subject
Next Message Klint Gore 2005-07-04 23:36:02 Re: plain inserts and deletes very slow
Previous Message David Gagnon 2005-07-04 19:57:49 Why the planner is not using the INDEX .