Skip to content

Commit

Permalink
Store zero-value table stats when diff doesn't exist (#647)
Browse files Browse the repository at this point in the history
  • Loading branch information
seanlinsley authored Dec 2, 2024
1 parent 59c9c10 commit 1b330c2
Showing 1 changed file with 56 additions and 56 deletions.
112 changes: 56 additions & 56 deletions output/transform/postgres_relations.go
Original file line number Diff line number Diff line change
Expand Up @@ -162,65 +162,65 @@ func transformPostgresRelations(s snapshot.FullSnapshot, newState state.Persiste
}
s.RelationInformations = append(s.RelationInformations, &info)

// Statistic
diffedSchemaStats, diffedSchemaStatsExist := diffState.SchemaStats[relation.DatabaseOid]
if diffedSchemaStatsExist {
stats, exists := diffedSchemaStats.RelationStats[relation.Oid]
if exists {
statistic := snapshot.RelationStatistic{
RelationIdx: relationIdx,
SizeBytes: stats.SizeBytes,
ToastSizeBytes: stats.ToastSizeBytes,
SeqScan: stats.SeqScan,
SeqTupRead: stats.SeqTupRead,
IdxScan: stats.IdxScan,
IdxTupFetch: stats.IdxTupFetch,
NTupIns: stats.NTupIns,
NTupUpd: stats.NTupUpd,
NTupDel: stats.NTupDel,
NTupHotUpd: stats.NTupHotUpd,
NLiveTup: stats.NLiveTup,
NDeadTup: stats.NDeadTup,
NModSinceAnalyze: stats.NModSinceAnalyze,
NInsSinceVacuum: stats.NInsSinceVacuum,
HeapBlksRead: stats.HeapBlksRead,
HeapBlksHit: stats.HeapBlksHit,
IdxBlksRead: stats.IdxBlksRead,
IdxBlksHit: stats.IdxBlksHit,
ToastBlksRead: stats.ToastBlksRead,
ToastBlksHit: stats.ToastBlksHit,
TidxBlksRead: stats.TidxBlksRead,
TidxBlksHit: stats.TidxBlksHit,
FrozenxidAge: stats.FrozenXIDAge,
MinmxidAge: stats.MinMXIDAge,
Relpages: stats.Relpages,
Reltuples: stats.Reltuples,
Relallvisible: stats.Relallvisible,
ToastReltuples: stats.ToastReltuples,
ToastRelpages: stats.ToastRelpages,
Relfrozenxid: relation.FullFrozenXID(currentXactId),
Relminmxid: int64(relation.MinimumMultixactXID),
LastVacuum: snapshot.NullTimeToNullTimestamp(stats.LastVacuum),
LastAutovacuum: snapshot.NullTimeToNullTimestamp(stats.LastAutovacuum),
LastAnalyze: snapshot.NullTimeToNullTimestamp(stats.LastAnalyze),
LastAutoanalyze: snapshot.NullTimeToNullTimestamp(stats.LastAutoanalyze),
CachedDataBytes: relation.CachedDataBytes,
CachedToastBytes: relation.CachedToastBytes,
}
if stats.LastAutoanalyze.Valid && (!stats.LastAnalyze.Valid || stats.LastAutoanalyze.Time.After(stats.LastAnalyze.Time)) {
statistic.AnalyzedAt = snapshot.NullTimeToNullTimestamp(stats.LastAutoanalyze)
} else {
statistic.AnalyzedAt = snapshot.NullTimeToNullTimestamp(stats.LastAnalyze)
}
s.RelationStatistics = append(s.RelationStatistics, &statistic)

// Events
s.RelationEvents = addRelationEvents(relationIdx, s.RelationEvents, stats.AnalyzeCount, stats.LastAnalyze, snapshot.RelationEvent_MANUAL_ANALYZE)
s.RelationEvents = addRelationEvents(relationIdx, s.RelationEvents, stats.AutoanalyzeCount, stats.LastAutoanalyze, snapshot.RelationEvent_AUTO_ANALYZE)
s.RelationEvents = addRelationEvents(relationIdx, s.RelationEvents, stats.VacuumCount, stats.LastVacuum, snapshot.RelationEvent_MANUAL_VACUUM)
s.RelationEvents = addRelationEvents(relationIdx, s.RelationEvents, stats.AutovacuumCount, stats.LastAutovacuum, snapshot.RelationEvent_AUTO_VACUUM)
}
// Statistic
var stats state.DiffedPostgresRelationStats
if diffedSchemaStatsExist {
stats = diffedSchemaStats.RelationStats[relation.Oid]
}
statistic := snapshot.RelationStatistic{
RelationIdx: relationIdx,
SizeBytes: stats.SizeBytes,
ToastSizeBytes: stats.ToastSizeBytes,
SeqScan: stats.SeqScan,
SeqTupRead: stats.SeqTupRead,
IdxScan: stats.IdxScan,
IdxTupFetch: stats.IdxTupFetch,
NTupIns: stats.NTupIns,
NTupUpd: stats.NTupUpd,
NTupDel: stats.NTupDel,
NTupHotUpd: stats.NTupHotUpd,
NLiveTup: stats.NLiveTup,
NDeadTup: stats.NDeadTup,
NModSinceAnalyze: stats.NModSinceAnalyze,
NInsSinceVacuum: stats.NInsSinceVacuum,
HeapBlksRead: stats.HeapBlksRead,
HeapBlksHit: stats.HeapBlksHit,
IdxBlksRead: stats.IdxBlksRead,
IdxBlksHit: stats.IdxBlksHit,
ToastBlksRead: stats.ToastBlksRead,
ToastBlksHit: stats.ToastBlksHit,
TidxBlksRead: stats.TidxBlksRead,
TidxBlksHit: stats.TidxBlksHit,
FrozenxidAge: stats.FrozenXIDAge,
MinmxidAge: stats.MinMXIDAge,
Relpages: stats.Relpages,
Reltuples: stats.Reltuples,
Relallvisible: stats.Relallvisible,
ToastReltuples: stats.ToastReltuples,
ToastRelpages: stats.ToastRelpages,
Relfrozenxid: relation.FullFrozenXID(currentXactId),
Relminmxid: int64(relation.MinimumMultixactXID),
LastVacuum: snapshot.NullTimeToNullTimestamp(stats.LastVacuum),
LastAutovacuum: snapshot.NullTimeToNullTimestamp(stats.LastAutovacuum),
LastAnalyze: snapshot.NullTimeToNullTimestamp(stats.LastAnalyze),
LastAutoanalyze: snapshot.NullTimeToNullTimestamp(stats.LastAutoanalyze),
CachedDataBytes: relation.CachedDataBytes,
CachedToastBytes: relation.CachedToastBytes,
}
if stats.LastAutoanalyze.Valid && (!stats.LastAnalyze.Valid || stats.LastAutoanalyze.Time.After(stats.LastAnalyze.Time)) {
statistic.AnalyzedAt = snapshot.NullTimeToNullTimestamp(stats.LastAutoanalyze)
} else {
statistic.AnalyzedAt = snapshot.NullTimeToNullTimestamp(stats.LastAnalyze)
}
s.RelationStatistics = append(s.RelationStatistics, &statistic)

// Events
s.RelationEvents = addRelationEvents(relationIdx, s.RelationEvents, stats.AnalyzeCount, stats.LastAnalyze, snapshot.RelationEvent_MANUAL_ANALYZE)
s.RelationEvents = addRelationEvents(relationIdx, s.RelationEvents, stats.AutoanalyzeCount, stats.LastAutoanalyze, snapshot.RelationEvent_AUTO_ANALYZE)
s.RelationEvents = addRelationEvents(relationIdx, s.RelationEvents, stats.VacuumCount, stats.LastVacuum, snapshot.RelationEvent_MANUAL_VACUUM)
s.RelationEvents = addRelationEvents(relationIdx, s.RelationEvents, stats.AutovacuumCount, stats.LastAutovacuum, snapshot.RelationEvent_AUTO_VACUUM)

// Indices
for _, index := range relation.Indices {
Expand Down

0 comments on commit 1b330c2

Please sign in to comment.