On Wed, May 11, 2016 at 9:36 PM, Lucas Possamai <drum.lu...@gmail.com>
wrote:

>
>>>
>> The main problem is WHERE title ILIKE '%RYAN WER%'
>> When you put a % on the left of the text, there is no way to optimize
>> that, so yes, it will be slow.
>>
>> If you can eliminate the leading percent and just have trailing, it will
>> be much faster.
>>
>>
>
> Hmm.. yep.. I suppose I can do that.
>
> But, taking the left % off, the query is still slow:
>
> Limit  (cost=418.57..418.58 rows=1 width=20) (actual
>> time=4439.367..4439.381 rows=1 loops=1)
>>   Buffers: shared hit=6847
>>   ->  Unique  (cost=418.57..418.58 rows=1 width=20) (actual
>> time=4439.363..4439.374 rows=1 loops=1)
>>         Buffers: shared hit=6847
>>         ->  Sort  (cost=418.57..418.58 rows=1 width=20) (actual
>> time=4439.360..4439.365 rows=4 loops=1)
>>               Sort Key: "title"
>>               Sort Method: quicksort  Memory: 25kB
>>               Buffers: shared hit=6847
>>               ->  Bitmap Heap Scan on "ja_jobs"  (cost=414.55..418.56
>> rows=1 width=20) (actual time=4439.312..4439.329 rows=4 loops=1)
>>                     Recheck Cond: (("clientid" = 31239) AND ("time_job" >
>> 1457826264) AND (("title")::"text" ~~* 'RYAN SHOWER%'::"text"))
>>                     Buffers: shared hit=6847
>>                     ->  BitmapAnd  (cost=414.55..414.55 rows=1 width=0)
>> (actual time=4439.280..4439.280 rows=0 loops=1)
>>                           Buffers: shared hit=6843
>>                           ->  Bitmap Index Scan on "ix_jobs_client_times"
>>  (cost=0.00..50.67 rows=1711 width=0) (actual time=0.142..0.142 rows=795
>> loops=1)
>>                                 Index Cond: (("clientid" = 31239) AND
>> ("time_job" > 1457826264))
>>                                 Buffers: shared hit=8
>>                           ->  Bitmap Index Scan on "ix_ja_jobs_trgm_gin"
>>  (cost=0.00..363.62 rows=483 width=0) (actual time=4439.014..4439.014
>> rows=32 loops=1)
>>                                 Index Cond: (("title")::"text" ~~* 'RYAN
>> SHOWER%'::"text")
>>                                 Buffers: shared hit=6835
>> Total runtime: 4439.427 ms
>
>
> Here [1] it appears to be working even with two %.. But it's not for
> me....
>
> [1] https://www.depesz.com/2011/02/19/waiting-for-9-1-faster-likeilike/
>
>
> Any ideia? lol
>

Trying redoing the query with CTE as below:

WITH ja_jobs as
  (SELECT DISTINCT title
     FROM ja_jobs
    WHERE clientid = 31239  AND time_job > 1457826264
  )
SELECT title
  FROM ja_jobs
 WHERE title ILIKE 'RYAN WER%'
 ORDER BY title
 LIMIT 10;


-- 
*Melvin Davidson*
I reserve the right to fantasize.  Whether or not you
wish to share my fantasy is entirely up to you.

Reply via email to