mirror of
https://github.com/postgres/postgres.git
synced 2026-03-23 10:55:21 -04:00
Simplify visibility check in heap_page_would_be_all_visible()
heap_page_would_be_all_visible() does not need to distinguish between HEAPTUPLE_RECENTLY_DEAD and HEAPTUPLE_DEAD tuples: any tuple in a state other than HEAPTUPLE_LIVE means the page is not all-visible and heap_page_would_be_all_visible() returns false. Given that, calling HeapTupleSatisfiesVacuum() is unnecessary, since it performs extra work to distinguish between dead and recently dead tuples using OldestXmin. Replace it with the more minimal HeapTupleSatisfiesVacuumHorizon(). Author: Melanie Plageman <melanieplageman@gmail.com> Reviewed-by: Kirill Reshke <reshkekirill@gmail.com> Reviewed-by: Andres Freund <andres@anarazel.de> Reviewed-by: Chao Li <li.evan.chao@gmail.com> Discussion: https://postgr.es/m/CALdSSPjvhGXihT_9f-GJabYU%3D_PjrFDUxYaURuTbfLyQM6TErg%40mail.gmail.com
This commit is contained in:
parent
c8308a984d
commit
3efe58febc
1 changed files with 2 additions and 1 deletions
|
|
@ -3739,6 +3739,7 @@ heap_page_would_be_all_visible(Relation rel, Buffer buf,
|
|||
{
|
||||
ItemId itemid;
|
||||
HeapTupleData tuple;
|
||||
TransactionId dead_after;
|
||||
|
||||
/*
|
||||
* Set the offset number so that we can display it along with any
|
||||
|
|
@ -3778,7 +3779,7 @@ heap_page_would_be_all_visible(Relation rel, Buffer buf,
|
|||
|
||||
/* Visibility checks may do IO or allocate memory */
|
||||
Assert(CritSectionCount == 0);
|
||||
switch (HeapTupleSatisfiesVacuum(&tuple, OldestXmin, buf))
|
||||
switch (HeapTupleSatisfiesVacuumHorizon(&tuple, buf, &dead_after))
|
||||
{
|
||||
case HEAPTUPLE_LIVE:
|
||||
{
|
||||
|
|
|
|||
Loading…
Reference in a new issue