Commit e42b3c3b authored by Peter Geoghegan's avatar Peter Geoghegan

Fix GiST index deletion assert issue.

Avoid calling heap_index_delete_tuples() with an empty deltids array to
avoid an assertion failure.

This issue was arguably an oversight in commit b5f58cf2, though the
failing assert itself was added by my recent commit d168b666.  No
backpatch, though, since the oversight is harmless in the back branches.

Author: Peter Geoghegan <pg@bowt.ie>
Reported-By: default avatarJaime Casanova <jcasanov@systemguards.com.ec>
Discussion: https://postgr.es/m/CAJKUy5jscES84n3puE=sYngyF+zpb4wv8UMtuLnLPv5z=6yyNw@mail.gmail.com
parent 32bef758
...@@ -1645,7 +1645,6 @@ gistprunepage(Relation rel, Page page, Buffer buffer, Relation heapRel) ...@@ -1645,7 +1645,6 @@ gistprunepage(Relation rel, Page page, Buffer buffer, Relation heapRel)
int ndeletable = 0; int ndeletable = 0;
OffsetNumber offnum, OffsetNumber offnum,
maxoff; maxoff;
TransactionId latestRemovedXid = InvalidTransactionId;
Assert(GistPageIsLeaf(page)); Assert(GistPageIsLeaf(page));
...@@ -1664,13 +1663,15 @@ gistprunepage(Relation rel, Page page, Buffer buffer, Relation heapRel) ...@@ -1664,13 +1663,15 @@ gistprunepage(Relation rel, Page page, Buffer buffer, Relation heapRel)
deletable[ndeletable++] = offnum; deletable[ndeletable++] = offnum;
} }
if (XLogStandbyInfoActive() && RelationNeedsWAL(rel))
latestRemovedXid =
index_compute_xid_horizon_for_tuples(rel, heapRel, buffer,
deletable, ndeletable);
if (ndeletable > 0) if (ndeletable > 0)
{ {
TransactionId latestRemovedXid = InvalidTransactionId;
if (XLogStandbyInfoActive() && RelationNeedsWAL(rel))
latestRemovedXid =
index_compute_xid_horizon_for_tuples(rel, heapRel, buffer,
deletable, ndeletable);
START_CRIT_SECTION(); START_CRIT_SECTION();
PageIndexMultiDelete(page, deletable, ndeletable); PageIndexMultiDelete(page, deletable, ndeletable);
......
...@@ -301,6 +301,8 @@ index_compute_xid_horizon_for_tuples(Relation irel, ...@@ -301,6 +301,8 @@ index_compute_xid_horizon_for_tuples(Relation irel,
Page ipage = BufferGetPage(ibuf); Page ipage = BufferGetPage(ibuf);
IndexTuple itup; IndexTuple itup;
Assert(nitems > 0);
delstate.bottomup = false; delstate.bottomup = false;
delstate.bottomupfreespace = 0; delstate.bottomupfreespace = 0;
delstate.ndeltids = 0; delstate.ndeltids = 0;
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment