]> git.ipfire.org Git - thirdparty/postgresql.git/commitdiff
Fix new pg_upgrade query not to rely on regnamespace
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 6f53dbba76b5236f036c8a9ec0961f924f6813cd..7e8365d89fabc406be21fbca5b7ba14cf8f9f30d 100644 (file)
@@ -1266,12 +1266,13 @@ check_for_not_null_inheritance(ClusterInfo *cluster)
                PGconn     *conn = connectToServer(&old_cluster, active_db->db_name);
 
                res = executeQueryOrDie(conn,
-                                                               "SELECT cc.relnamespace::pg_catalog.regnamespace AS nspname, "
-                                                               "       cc.relname, ac.attname "
+                                                               "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");
 
                ntup = PQntuples(res);