diff options
| author | Bruce Momjian <bruce@momjian.us> | 2011-01-05 11:37:08 -0500 | 
|---|---|---|
| committer | Bruce Momjian <bruce@momjian.us> | 2011-01-05 11:37:08 -0500 | 
| commit | 5cff5b577918cf29e0ba3a35158c27cfe2de280c (patch) | |
| tree | 7ca79495ef7284f5d3847cfd4ff69ee1ef4b7618 /src | |
| parent | 66a8a0428db046d725b88c8b956384c2a4b4a11c (diff) | |
Clarify pg_upgrade's creation of the map file structure.  Also clean
up pg_dump's calling of pg_upgrade_support functions.
Diffstat (limited to 'src')
| -rw-r--r-- | src/bin/pg_dump/pg_dump.c | 43 | 
1 files changed, 23 insertions, 20 deletions
| diff --git a/src/bin/pg_dump/pg_dump.c b/src/bin/pg_dump/pg_dump.c index b0a0dc56072..95218ee8317 100644 --- a/src/bin/pg_dump/pg_dump.c +++ b/src/bin/pg_dump/pg_dump.c @@ -2354,34 +2354,37 @@ binary_upgrade_set_relfilenodes(PQExpBuffer upgrade_buffer, Oid pg_class_oid,  					"\n-- For binary upgrade, must preserve relfilenodes\n");  	if (!is_index) +	{  		appendPQExpBuffer(upgrade_buffer,  						  "SELECT binary_upgrade.set_next_heap_relfilenode('%u'::pg_catalog.oid);\n",  						  pg_class_relfilenode); +		/* only tables have toast tables, not indexes */ +		if (OidIsValid(pg_class_reltoastrelid)) +		{ +			/* +			 * One complexity is that the table definition might not require the +			 * creation of a TOAST table, and the TOAST table might have been +			 * created long after table creation, when the table was loaded with +			 * wide data.  By setting the TOAST relfilenode we force creation of +			 * the TOAST heap and TOAST index by the backend so we can cleanly +			 * migrate the files during binary migration. +			 */ +	 +			appendPQExpBuffer(upgrade_buffer, +							  "SELECT binary_upgrade.set_next_toast_relfilenode('%u'::pg_catalog.oid);\n", +							  pg_class_reltoastrelid); +	 +			/* every toast table has an index */ +			appendPQExpBuffer(upgrade_buffer, +							  "SELECT binary_upgrade.set_next_index_relfilenode('%u'::pg_catalog.oid);\n", +							  pg_class_reltoastidxid); +		} +	}  	else  		appendPQExpBuffer(upgrade_buffer,  						  "SELECT binary_upgrade.set_next_index_relfilenode('%u'::pg_catalog.oid);\n",  						  pg_class_relfilenode); -	if (OidIsValid(pg_class_reltoastrelid)) -	{ -		/* -		 * One complexity is that the table definition might not require the -		 * creation of a TOAST table, and the TOAST table might have been -		 * created long after table creation, when the table was loaded with -		 * wide data.  By setting the TOAST relfilenode we force creation of -		 * the TOAST heap and TOAST index by the backend so we can cleanly -		 * migrate the files during binary migration. -		 */ - -		appendPQExpBuffer(upgrade_buffer, -						  "SELECT binary_upgrade.set_next_toast_relfilenode('%u'::pg_catalog.oid);\n", -						  pg_class_reltoastrelid); - -		/* every toast table has an index */ -		appendPQExpBuffer(upgrade_buffer, -						  "SELECT binary_upgrade.set_next_index_relfilenode('%u'::pg_catalog.oid);\n", -						  pg_class_reltoastidxid); -	}  	appendPQExpBuffer(upgrade_buffer, "\n");  	PQclear(upgrade_res); | 
