]> granicus.if.org Git - postgresql/commit
Avoid assuming that index-only scan data matches the index's rowtype.
authorTom Lane <tgl@sss.pgh.pa.us>
Sun, 16 Oct 2011 23:15:04 +0000 (19:15 -0400)
committerTom Lane <tgl@sss.pgh.pa.us>
Sun, 16 Oct 2011 23:15:04 +0000 (19:15 -0400)
commit336c1d7a515b4d6de237679022d70082d7b69d9a
treea809a1fdbdd674eb885b8b15559d54ea7cda090b
parente661c3dfd320487aaa1d6223e732e00c1b5c3cc2
Avoid assuming that index-only scan data matches the index's rowtype.

In general the data returned by an index-only scan should have the
datatypes originally computed by FormIndexDatum.  If the index opclasses
use "storage" datatypes different from their input datatypes, the scan
tuple will not have the same rowtype attributed to the index; but we had
a hard-wired assumption that that was true in nodeIndexonlyscan.c.  We'd
already hacked around the issue for the one case where the types are
different in btree indexes (btree name_ops), but this would definitely
come back to bite us if we ever implement index-only scans in GiST.

To fix, require the index AM to explicitly provide the tupdesc for the
tuple it is returning.  btree can just pass back the index's tupdesc, but
GiST will have to work harder when and if it supports index-only scans.

I had previously proposed fixing this by allowing the index AM to fill the
scan tuple slot directly; but on reflection that seemed like a module
layering violation, since TupleTableSlots are creatures of the executor.
At least in the btree case, it would also be less efficient, since the
tuple deconstruction work would occur even for rows later found to be
invisible to the scan's snapshot.
doc/src/sgml/indexam.sgml
src/backend/access/index/genam.c
src/backend/access/nbtree/nbtree.c
src/backend/executor/nodeIndexonlyscan.c
src/include/access/relscan.h