LIMIT 1 poor query plan

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Hail there,

Short question:
Why would pg optimizer choose a worst (slower) query plan for a
query with 'LIMIT 1' instead of, say, 'LIMIT 3'?

Complete scenario:
Query: 'SELECT * FROM a WHERE a.b_id = 42 ORDER BY created LIMIT 1'
- b_id is a FK to b;
- created is a datetime with the time of the creation of the row;
- both 'b' and 'created' are indexed separately

This query, with the LIMIT 1, uses the index on created, which is much
slower (10x) than if it used the index on b_id

If I change the LIMIT from 1 to 3 pg starts using the index on b_id.

Already tried running REINDEX and VACUUM ANALYZE on both A and B.
Nothing changed.

Why does this happen?
Is there any way I can hint/force the optimizer to use b_id index?

Thanks

--
Marcio Ribeiro

[Postgresql General]     [Postgresql PHP]     [PHP Users]     [PHP Home]     [PHP on Windows]     [Kernel Newbies]     [PHP Classes]     [PHP Books]     [PHP Databases]     [Yosemite]

  Powered by Linux