Allow indexscans on partial hash indexes with implied quals.
authorTom Lane <[email protected]>
Thu, 27 Nov 2025 18:09:59 +0000 (13:09 -0500)
committerTom Lane <[email protected]>
Thu, 27 Nov 2025 18:09:59 +0000 (13:09 -0500)
commitf19502f04edc97f124db39faa388c9b54b7383cf
tree1c96408c606a8763062a72552ca47b2608eb3588
parentf9f928304bb720d5e94651acd6b3e71a6f267430
Allow indexscans on partial hash indexes with implied quals.

Normally, if a WHERE clause is implied by the predicate of a partial
index, we drop that clause from the set of quals used with the index,
since it's redundant to test it if we're scanning that index.
However, if it's a hash index (or any !amoptionalkey index), this
could result in dropping all available quals for the index's first
key, preventing us from generating an indexscan.

It's fair to question the practical usefulness of this case.  Since
hash only supports equality quals, the situation could only arise
if the index's predicate is "WHERE indexkey = constant", implying
that the index contains only one hash value, which would make hash
a really poor choice of index type.  However, perhaps there are
other !amoptionalkey index AMs out there with which such cases are
more plausible.

To fix, just don't filter the candidate indexquals this way if
the index is !amoptionalkey.  That's a bit hokey because it may
result in testing quals we didn't need to test, but to do it
more accurately we'd have to redundantly identify which candidate
quals are actually usable with the index, something we don't know
at this early stage of planning.  Doesn't seem worth the effort.

Reported-by: Sergei Glukhov <[email protected]>
Author: Tom Lane <[email protected]>
Reviewed-by: David Rowley <[email protected]>
Discussion: https://postgr.es/m/e200bf38-6b45-446a-83fd-48617211feff@postgrespro.ru
Backpatch-through: 14
src/backend/optimizer/path/indxpath.c
src/test/regress/expected/hash_index.out
src/test/regress/sql/hash_index.sql