Commit b06679e0 authored by Simon Riggs's avatar Simon Riggs

Ensure age() returns a stable value rather than the latest value

parent 3652d72d
...@@ -391,6 +391,28 @@ GetCurrentTransactionIdIfAny(void) ...@@ -391,6 +391,28 @@ GetCurrentTransactionIdIfAny(void)
} }
/*
* GetStableLatestTransactionIdIfAny
*
* Get the latest XID once and then return same value for rest of transaction.
* Acts as a useful reference point for maintenance tasks.
*/
TransactionId
GetStableLatestTransactionId(void)
{
static LocalTransactionId lxid = InvalidLocalTransactionId;
static TransactionId stablexid = InvalidTransactionId;
if (lxid != MyProc->lxid ||
!TransactionIdIsValid(stablexid))
{
lxid = MyProc->lxid;
stablexid = ReadNewTransactionId();
}
return stablexid;
}
/* /*
* AssignTransactionId * AssignTransactionId
* *
......
...@@ -19,6 +19,7 @@ ...@@ -19,6 +19,7 @@
#include "access/transam.h" #include "access/transam.h"
#include "access/xact.h" #include "access/xact.h"
#include "libpq/pqformat.h" #include "libpq/pqformat.h"
#include "storage/proc.h"
#include "utils/builtins.h" #include "utils/builtins.h"
#define PG_GETARG_TRANSACTIONID(n) DatumGetTransactionId(PG_GETARG_DATUM(n)) #define PG_GETARG_TRANSACTIONID(n) DatumGetTransactionId(PG_GETARG_DATUM(n))
...@@ -87,16 +88,13 @@ xideq(PG_FUNCTION_ARGS) ...@@ -87,16 +88,13 @@ xideq(PG_FUNCTION_ARGS)
} }
/* /*
* xid_age - compute age of an XID (relative to current xact) * xid_age - compute age of an XID (relative to latest stable xid)
*/ */
Datum Datum
xid_age(PG_FUNCTION_ARGS) xid_age(PG_FUNCTION_ARGS)
{ {
TransactionId xid = PG_GETARG_TRANSACTIONID(0); TransactionId xid = PG_GETARG_TRANSACTIONID(0);
TransactionId now = GetTopTransactionIdIfAny(); TransactionId now = GetStableLatestTransactionId();
if (!TransactionIdIsValid(now))
now = ReadNewTransactionId();
/* Permanent XIDs are always infinitely old */ /* Permanent XIDs are always infinitely old */
if (!TransactionIdIsNormal(xid)) if (!TransactionIdIsNormal(xid))
......
...@@ -209,6 +209,7 @@ extern TransactionId GetTopTransactionId(void); ...@@ -209,6 +209,7 @@ extern TransactionId GetTopTransactionId(void);
extern TransactionId GetTopTransactionIdIfAny(void); extern TransactionId GetTopTransactionIdIfAny(void);
extern TransactionId GetCurrentTransactionId(void); extern TransactionId GetCurrentTransactionId(void);
extern TransactionId GetCurrentTransactionIdIfAny(void); extern TransactionId GetCurrentTransactionIdIfAny(void);
extern TransactionId GetStableLatestTransactionId(void);
extern SubTransactionId GetCurrentSubTransactionId(void); extern SubTransactionId GetCurrentSubTransactionId(void);
extern CommandId GetCurrentCommandId(bool used); extern CommandId GetCurrentCommandId(bool used);
extern TimestampTz GetCurrentTransactionStartTimestamp(void); extern TimestampTz GetCurrentTransactionStartTimestamp(void);
......
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