LIKE on index not working - Mailing list pgsql-sql

From Chris Cox
Subject LIKE on index not working
Date
Msg-id 030e01c46fbe$e8baeb90$5100000a@PHOENIX
Whole thread Raw
Responses Re: LIKE on index not working  (Peter Eisentraut <peter_e@gmx.net>)
Re: LIKE on index not working  (Tom Lane <tgl@sss.pgh.pa.us>)
List pgsql-sql
Hi all,

For some reason I just can't get this to use the index for the following
query.  I'm using PostgreSQL 7.3.4.

Here's the details (let me know if you need anymore information to provide
any assistance):

Indexes: person_pkey primary key btree (personid),        ix_person_active btree (bactive),        ix_person_fullname
btree(tsurname, tfirstname),        ix_person_member btree (bmember),        ix_person_supporter btree (bsupporter),
   ix_person_surname btree (lower(tsurname))
 

smartteamscouts=# explain analyze select * from person where bmember = 1 AND
lower(tsurname) like lower('weaver');                                               QUERY PLAN
----------------------------------------------------------------------------
-------------------------------Seq Scan on person  (cost=0.00..12946.58 rows=310 width=416) (actual
time=873.94..1899.09 rows=6 loops=1)  Filter: ((bmember = 1) AND (lower((tsurname)::text) ~~ 'weaver'::text))Total
runtime:1899.64 msec
 
(3 rows)

smartteamscouts=# explain analyze select * from person where bmember = 1 AND
lower(tsurname) = lower('weaver');                                                         QUERY PLAN
----------------------------------------------------------------------------
---------------------------------------------------Index Scan using ix_person_surname on person  (cost=0.00..1265.78
rows=310
width=416) (actual time=0.91..2.03 rows=6 loops=1)  Index Cond: (lower((tsurname)::text) = 'weaver'::text)  Filter:
(bmember= 1)Total runtime: 2.36 msec
 
(4 rows)

As you can see, using the '=' operator it works just fine, but as soon as
the 'like' operator comes into it, no good.

Is this a bug in 7.3.4? Or is it something else I need to adjust?

Thanks for your help!

Chris




pgsql-sql by date:

Previous
From: Oliver Elphick
Date:
Subject: Re: next integer in serial key
Next
From: "cristi"
Date:
Subject: connection delay