Re: LIKE query verses = - Mailing list pgsql-performance
From | Mark Lewis |
---|---|
Subject | Re: LIKE query verses = |
Date | |
Msg-id | 1188407551.22730.113.camel@archimedes Whole thread Raw |
In response to | LIKE query verses = (Karthikeyan Mahadevan <karthikeyan.mahadevan@in.ibm.com>) |
Responses |
Re: LIKE query verses =
|
List | pgsql-performance |
On Wed, 2007-08-29 at 18:01 +0530, Karthikeyan Mahadevan wrote: > > ************************************************************************************************************************* > 1) > > EXPLAIN ANALYSE SELECT > job_category.job_id,job.name,job.state,job.build_id,cat.name as > reporting_group > FROM category,job_category,job,category as cat > WHERE job.job_id=job_category.job_id > AND job_category.category_id=category.category_id > AND cat.build_id=category.build_id > AND category.name = 'build_id.pap3260-20070828_01' > AND cat.name like ('reporting_group.Tier2%'); > > QUERY PLAN > ------------------------------------------------------------------------------------------------------------------------------------------------------ > Nested Loop (cost=0.00..291.53 rows=8 width=103) (actual > time=98.999..385.590 rows=100 loops=1) > -> Nested Loop (cost=0.00..250.12 rows=9 width=34) (actual > time=98.854..381.106 rows=100 loops=1) > -> Nested Loop (cost=0.00..123.22 rows=1 width=34) (actual > time=98.717..380.185 rows=1 loops=1) > -> Index Scan using idx_cat_by_name on category cat > (cost=0.00..5.97 rows=1 width=34) (actual time=95.834..245.276 > rows=977 loops=1) > Index Cond: (((name)::text >= > 'reporting'::character varying) AND ((name)::text < > 'reportinh'::character varying)) > Filter: ((name)::text ~~ > 'reporting_group.Tier2%'::text) > -> Index Scan using idx_cat_by_bld_id on category > (cost=0.00..117.24 rows=1 width=8) (actual time=0.134..0.134 rows=0 > loops=977) > Index Cond: ("outer".build_id = > category.build_id) > Filter: ((name)::text = > 'build_id.pap3260-20070828_01'::text) > -> Index Scan using idx_jcat_by_cat_id on job_category > (cost=0.00..126.00 rows=71 width=8) (actual time=0.126..0.569 > rows=100 loops=1) > Index Cond: (job_category.category_id = > "outer".category_id) > -> Index Scan using job_pkey on job (cost=0.00..4.59 rows=1 > width=73) (actual time=0.033..0.036 rows=1 loops=100) > Index Cond: (job.job_id = "outer".job_id) > > Total runtime: 385.882 ms > ------------------------------------------------------------------------------------------------------------------------------------------------------ Remember that using LIKE causes PG to interpret an underscore as 'any character', which means that it can only scan the index for all records that start with 'reporting', and then it needs to apply a filter to each match. This is going to be slower than just going directly to the matching index entry. What you probably want to do is tell PG that you're looking for a literal underscore and not for any matching character by escaping the underscore, that will allow it to do a much quicker index scan. Something like: cat.name like 'reporting|_group.Tier2%' ESCAPE '|' -- Mark Lewis
pgsql-performance by date: