]> git.ipfire.org Git - thirdparty/postgresql.git/commitdiff
Fix new pg_upgrade query not to rely on regnamespace REL_18_STABLE github/REL_18_STABLE
authorÁlvaro Herrera <alvherre@kurilemu.de>
Fri, 4 Jul 2025 19:30:05 +0000 (21:30 +0200)
committerÁlvaro Herrera <alvherre@kurilemu.de>
Fri, 4 Jul 2025 19:30:05 +0000 (21:30 +0200)
That was invented in 9.5, and pg_upgrade claims to support back to 9.0.
But we don't need that with a simple query change, tested by Tom Lane.

Discussion: https://postgr.es/m/202507041645.afjl5rssvrgu@alvherre.pgsql

src/bin/pg_upgrade/check.c

index 5eac4073fc3ff1e269947ddc0ce3f7b0c1c2864c..bb6d588a2ec6d9094b8f30548e067dee9cecdb94 100644 (file)
@@ -1688,12 +1688,13 @@ check_for_not_null_inheritance(ClusterInfo *cluster)
                         log_opts.basedir,
                         "not_null_inconsistent_columns.txt");
 
-       query = "SELECT cc.relnamespace::pg_catalog.regnamespace AS nspname, "
-               "       cc.relname, ac.attname "
+       query = "SELECT nspname, cc.relname, ac.attname "
                "FROM pg_catalog.pg_inherits i, pg_catalog.pg_attribute ac, "
-               "     pg_catalog.pg_attribute ap, pg_catalog.pg_class cc "
+               "     pg_catalog.pg_attribute ap, pg_catalog.pg_class cc, "
+               "     pg_catalog.pg_namespace nc "
                "WHERE cc.oid = ac.attrelid AND i.inhrelid = ac.attrelid "
                "      AND i.inhparent = ap.attrelid AND ac.attname = ap.attname "
+               "      AND cc.relnamespace = nc.oid "
                "      AND ap.attnum > 0 and ap.attnotnull AND NOT ac.attnotnull";
 
        task = upgrade_task_create();