Fixed repairing graph entry point

This commit is contained in:
Andrew Kane
2023-08-04 21:02:45 -07:00
parent f55bf54588
commit 7194c0281c
2 changed files with 11 additions and 1 deletions

View File

@@ -846,15 +846,22 @@ HnswInsertElement(HnswElement element, HnswElement entryPoint, Relation index, F
HnswElement dup;
BlockNumber *skipPage = vacuuming ? &element->neighborPage : NULL;
OffsetNumber *skipOffno = vacuuming ? &element->neighborOffno : NULL;
bool removeEntryPoint;
HnswCandidate *entryCandidate;
/* Get entry point and level */
if (entryPoint != NULL)
{
ep = lappend(ep, EntryCandidate(entryPoint, q, index, procinfo, collation, true));
entryCandidate = EntryCandidate(entryPoint, q, index, procinfo, collation, true);
ep = lappend(ep, entryCandidate);
entryLevel = entryPoint->level;
removeEntryPoint = vacuuming && list_length(entryPoint->heaptids) == 0;
}
else
{
entryLevel = -1;
removeEntryPoint = false;
}
for (int lc = entryLevel; lc >= level + 1; lc--)
{
@@ -870,6 +877,8 @@ HnswInsertElement(HnswElement element, HnswElement entryPoint, Relation index, F
int lm = GetLayerM(m, lc);
w = SearchLayer(q, ep, efConstruction, lc, index, procinfo, collation, true, skipPage, skipOffno);
if (removeEntryPoint)
w = list_delete_ptr(w, entryCandidate);
newNeighbors[lc] = SelectNeighbors(w, lm, lc, procinfo, collation, NULL);
ep = w;
}

View File

@@ -214,6 +214,7 @@ RepairGraphElement(HnswVacuumState * vacuumstate, HnswElement element)
return;
entryPoint = &vacuumstate->highestPoint;
entryPoint->neighbors = NULL;
}
else
entryPoint = NULL;