Hello,

on this table:

                                          Table "public.gruorari_tmp"
  Column   |          Type          |                                Modifiers
-----------+------------------------+--------------------------------------------------------------------------
 id        | numeric(1000,1)        | not null default 
function_get_next_sequence('gruorari_tmp_id_seq'::text)
 idgrucate | numeric(1000,1)        |
 dalle     | time without time zone |
 alle      | time without time zone |
 gg_sett   | integer                |
 azione    | character varying      |
Indexes:
    "keygruorari_tmp" PRIMARY KEY, btree (id)
    "gruorari_tmp_alle_idx" btree (alle)
    "gruorari_tmp_dalle_alle_idx" btree (dalle, alle)
    "gruorari_tmp_dalle_idx" btree (dalle)
    "gruorari_tmp_gg_sett_idx" btree (gg_sett)
    "gruorari_tmp_idgrucate_idx" btree (idgrucate)

i have a specific condition (i report example value):
"and ( gruorari_tmp.id is null or ( 2 = gg_sett and '16:00:00'::time between 
gruorari_tmp.dalle and gruorari_tmp.alle ) )"

But in the query planner, at that point, Postgresql 9.6.1 seems not to use any 
index (single on dalle / alle field and combindex index on dalle+alle) but it 
use seqscan:

Seq Scan on gruorari_tmp  (cost=0.00..5.90 rows=290 width=68) (actual 
time=0.014..0.062 rows=290 loops=1)
                                 ->  Hash  (cost=164.06..164.06 rows=1 
width=29) (actual time=0.770..0.770 rows=1 loops=1)
And it seems to be the main cost for the whole query.
Which kind of index should i use for that condition/fields?

Thank you!

/F

Reply via email to