| From: | Andreas Joseph Krogh <andreas(at)visena(dot)com> | 
|---|---|
| To: | pgsql-performance(at)postgresql(dot)org | 
| Subject: | Re: Searching GIN-index (FTS) and sort by timestamp-column | 
| Date: | 2016-03-16 15:17:40 | 
| Message-ID: | VisenaEmail.5a.f9605356ce0ed402.1537ff9da7e@tc7-visena | 
| Views: | Whole Thread | Raw Message | Download mbox | Resend email | 
| Thread: | |
| Lists: | pgsql-performance | 
På onsdag 16. mars 2016 kl. 16:07:56, skrev Evgeniy Shishkin <
itparanoia(at)gmail(dot)com <mailto:itparanoia(at)gmail(dot)com>>:
 > On 16 Mar 2016, at 18:04, Evgeniy Shishkin <itparanoia(at)gmail(dot)com> wrote:
 >
 >>
 >> On 16 Mar 2016, at 17:52, Evgeniy Shishkin <itparanoia(at)gmail(dot)com> wrote:
 >>
 >>
 >>> On 16 Mar 2016, at 16:37, Tom Lane <tgl(at)sss(dot)pgh(dot)pa(dot)us> wrote:
 >>>
 >>> Andreas Joseph Krogh <andreas(at)visena(dot)com> writes:
 >>>> 1. Why isnt' folder_id part of the index-cond?
 >>>
 >>> Because a GIN index is useless for sorting.
 >>
 >> I don't see how gin inability to return sorted data relates to index 
condition.
 >> In fact i tried to reproduce the example,
 >> and if i change folder_id to int from bigint, then index condition with 
folder_id is used
 >>
 >>        Index Cond: ((fts_all @@ '''hi'''::tsquery) AND (folder_id = 1))
 >>
 >
 > Looks like documentation 
http://www.postgresql.org/docs/9.5/static/btree-gin.html
 > is lying about supporting int8 type
 >
 Uh, it works if i cast to bigint explicitly
       WHERE  del.fts_all @@ to_tsquery('simple', 'hi')
       AND del.folder_id = 1::bigint;
 results in
          Index Cond: ((folder_id = '1'::bigint) AND (fts_all @@ 
'''hi'''::tsquery))
 
Hm, this is quite cranky, but thanks for the heads-up!
 
Tho it looks like it works if prepared, without explicit cast:
 
prepare fish AS  SELECT del.id , del.received_timestamp FROM delivery del WHERE
1= 1 AND del.fts_all @@ to_tsquery('simple', $1) AND del.folder_id = $2 ORDER BY
del.received_timestampDESC LIMIT 101 OFFSET 0; explain analyze execute fish(
'hi:*', 1);                                                          QUERY 
PLAN                                                         
 
────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────
  Limit  (cost=9.13..9.13 rows=1 width=16) (actual time=0.047..0.048 rows=2 
loops=1)
    ->  Sort  (cost=9.13..9.13 rows=1 width=16) (actual time=0.045..0.045 
rows=2 loops=1)
          Sort Key: received_timestamp DESC
          Sort Method: quicksort  Memory: 25kB
          ->  Bitmap Heap Scan on delivery del  (cost=7.80..9.12 rows=1 
width=16) (actual time=0.034..0.034 rows=2 loops=1)
                Recheck Cond: ((fts_all @@ '''hi'':*'::tsquery) AND (folder_id 
= '1'::bigint))
                Heap Blocks: exact=1
                ->  Bitmap Index Scan on fts_idx  (cost=0.00..7.80 rows=1 
width=0) (actual time=0.023..0.023 rows=2 loops=1)
                      Index Cond: ((fts_all @@ '''hi'':*'::tsquery) AND 
(folder_id = '1'::bigint))
  Execution time: 0.103 ms
 (10 rows)
 
 
-- Andreas Joseph Krogh
CTO / Partner - Visena AS
Mobile: +47 909 56 963
andreas(at)visena(dot)com <mailto:andreas(at)visena(dot)com>
www.visena.com <https://www.visena.com>
 <https://www.visena.com>
 
| From | Date | Subject | |
|---|---|---|---|
| Next Message | Doiron, Daniel | 2016-03-16 20:23:05 | Nested Loop vs Hash Join based on predicate? | 
| Previous Message | Andreas Joseph Krogh | 2016-03-16 15:08:04 | Re: Searching GIN-index (FTS) and sort by timestamp-column |