From 37dec08cf81ef959f3f72cc7cae49003e2b6bf9b Mon Sep 17 00:00:00 2001 From: Eric Radman Date: Fri, 12 Jul 2024 10:51:03 -0400 Subject: [PATCH] Repack all tables smallest to largest Free up space early to improve the overhead for repacking large tables. Preserve ordering by relname, schemaname for tests if MAKELEVEL is defined. --- bin/pg_repack.c | 9 +++++++-- 1 file changed, 7 insertions(+), 2 deletions(-) diff --git a/bin/pg_repack.c b/bin/pg_repack.c index 5dc377a..330d80d 100644 --- a/bin/pg_repack.c +++ b/bin/pg_repack.c @@ -874,8 +874,13 @@ repack_one_database(const char *orderby, char *errbuf, size_t errsize) appendStringInfoString(&sql, ")"); } - /* Ensure the regression tests get a consistent ordering of tables */ - appendStringInfoString(&sql, " ORDER BY t.relname, t.schemaname"); + /* Ensure the regression tests get a consistent ordering of tables + * Otherwise repack small objects first to free space on disk + */ + if (getenv("MAKELEVEL")) + appendStringInfoString(&sql, " ORDER BY t.relname, t.schemaname"); + else + appendStringInfoString(&sql, " ORDER BY pg_relation_size(t.relid)"); /* double check the parameters array is sane */ if (iparam != num_params)