Use pg_dump's --quote-all-identifiers option in pg_upgrade.
authorTom Lane <tgl@sss.pgh.pa.us>
Thu, 9 May 2013 21:34:34 +0000 (17:34 -0400)
committerTom Lane <tgl@sss.pgh.pa.us>
Thu, 9 May 2013 21:34:34 +0000 (17:34 -0400)
This helps guard against changes in the set of reserved keywords from
one version to another.  In theory it should only be an issue if we
de-reserve a keyword in a newer release, since that can create the type
of problem shown in bug #8128.

Back-patch to 9.1 where the --quote-all-identifiers option was added.

contrib/pg_upgrade/dump.c

index 66d4846eae583b1deaee9e44a43f1cbd7705daa1..8bf726b4c8d5404718cd3369386f2f167eed6dfa 100644 (file)
@@ -22,7 +22,8 @@ generate_old_dump(void)
 
    /* run new pg_dumpall binary for globals */
    exec_prog(UTILITY_LOG_FILE, NULL, true,
-             "\"%s/pg_dumpall\" %s --schema-only --globals-only --binary-upgrade %s -f %s",
+             "\"%s/pg_dumpall\" %s --schema-only --globals-only "
+             "--quote-all-identifiers --binary-upgrade %s -f %s",
              new_cluster.bindir, cluster_conn_opts(&old_cluster),
              log_opts.verbose ? "--verbose" : "",
              GLOBALS_DUMP_FILE);
@@ -30,26 +31,29 @@ generate_old_dump(void)
 
    prep_status("Creating dump of database schemas\n");
 
-   /* create per-db dump files */
+   /* create per-db dump files */
    for (dbnum = 0; dbnum < old_cluster.dbarr.ndbs; dbnum++)
    {
-       char        sql_file_name[MAXPGPATH], log_file_name[MAXPGPATH];
-       DbInfo     *old_db = &old_cluster.dbarr.dbs[dbnum];
+       char        sql_file_name[MAXPGPATH],
+                   log_file_name[MAXPGPATH];
+       DbInfo     *old_db = &old_cluster.dbarr.dbs[dbnum];
 
        pg_log(PG_STATUS, "%s", old_db->db_name);
        snprintf(sql_file_name, sizeof(sql_file_name), DB_DUMP_FILE_MASK, old_db->db_oid);
        snprintf(log_file_name, sizeof(log_file_name), DB_DUMP_LOG_FILE_MASK, old_db->db_oid);
 
        parallel_exec_prog(log_file_name, NULL,
-                 "\"%s/pg_dump\" %s --schema-only --binary-upgrade --format=custom %s --file=\"%s\" \"%s\"",
-                 new_cluster.bindir, cluster_conn_opts(&old_cluster),
-                 log_opts.verbose ? "--verbose" : "", sql_file_name, old_db->db_name);
+                  "\"%s/pg_dump\" %s --schema-only --quote-all-identifiers "
+                 "--binary-upgrade --format=custom %s --file=\"%s\" \"%s\"",
+                        new_cluster.bindir, cluster_conn_opts(&old_cluster),
+                          log_opts.verbose ? "--verbose" : "",
+                          sql_file_name, old_db->db_name);
    }
 
    /* reap all children */
    while (reap_child(true) == true)
        ;
-               
+
    end_progress_output();
    check_ok();
 }