On Mon, 21 Jul 2003, Philip Greer wrote:

> dumps=# \d fal_profdel
>                Table "fal_profdel"
>  Attribute |           Type           | Modifier
> -----------+--------------------------+----------
>  sid       | character(4)             | not null
>  card_num  | character(19)            | not null
>  date_del  | timestamp with time zone |
>  filename  | character varying(30)    |
> Indices: fal_prfdel_cn,
>          fal_prfdel_date,
>          fal_prfdel_pk
>
> dumps=# \d fal_prfdel_cn
>    Index "fal_prfdel_cn"
>  Attribute |     Type
> -----------+---------------
>  card_num  | character(19)
> unique btree
>
> dumps=# explain select card_num from fal_profdel where card_num = 
> 'removed_for_privacy';
> NOTICE:  QUERY PLAN:
>
> Seq Scan on fal_profdel  (cost=0.00..120546.39 rows=46649 width=12)
>
> EXPLAIN
> ================================================================================
>
> Now, why the heck is the select query not using the index? I've tried
> it by having an exact 19 character card_num as well - still explains
> as a 'Seq Scan' (tablespace scan) - and each query takes up to 37
> seconds (thus confirming that it is indeed doing scans and not using
> the index).

Have you vacuum analyzed the table recently? What does explain show if you
do set enable_seqscan=off; before the explain and then how long does the
query actually take to run with seqscan disabled.


---------------------------(end of broadcast)---------------------------
TIP 9: the planner will ignore your desire to choose an index scan if your
      joining column's datatypes do not match

Reply via email to