Commit d3adaaba authored by Tom Lane's avatar Tom Lane

Revert "pg_dump: Lock all relations, not just plain tables".

Revert 403a3d91, as well as the followup fix 7f423503, in all
branches.  We need to think a bit harder about what the behavior
of LOCK TABLE on views should be, and there's no time for that
before next week's releases.  We'll take another crack at this
later.

Discussion: https://postgr.es/m/16703-e348f58aab3cf6cc@postgresql.org
parent 53f614f1
...@@ -199,8 +199,6 @@ typedef struct Archive ...@@ -199,8 +199,6 @@ typedef struct Archive
int minRemoteVersion; /* allowable range */ int minRemoteVersion; /* allowable range */
int maxRemoteVersion; int maxRemoteVersion;
bool hasGenericLockTable; /* can LOCK TABLE do non-table rels */
int numWorkers; /* number of parallel processes */ int numWorkers; /* number of parallel processes */
char *sync_snapshot_id; /* sync snapshot id for parallel operation */ char *sync_snapshot_id; /* sync snapshot id for parallel operation */
......
...@@ -531,72 +531,6 @@ EndDBCopyMode(Archive *AHX, const char *tocEntryTag) ...@@ -531,72 +531,6 @@ EndDBCopyMode(Archive *AHX, const char *tocEntryTag)
} }
} }
/*
* Does LOCK TABLE work on non-table relations on this server?
*
* Note: assumes it is called out of any transaction
*/
bool
IsLockTableGeneric(Archive *AHX)
{
ArchiveHandle *AH = (ArchiveHandle *) AHX;
PGresult *res;
char *sqlstate;
bool retval;
if (AHX->remoteVersion >= 140000)
return true;
else if (AHX->remoteVersion < 90500)
return false;
StartTransaction(AHX);
/*
* Try a LOCK TABLE on a well-known non-table catalog; WRONG_OBJECT_TYPE
* tells us that this server doesn't support locking non-table rels, while
* LOCK_NOT_AVAILABLE and INSUFFICIENT_PRIVILEGE tell us that it does.
* Report anything else as a fatal problem.
*/
#define ERRCODE_INSUFFICIENT_PRIVILEGE "42501"
#define ERRCODE_WRONG_OBJECT_TYPE "42809"
#define ERRCODE_LOCK_NOT_AVAILABLE "55P03"
res = PQexec(AH->connection,
"LOCK TABLE pg_catalog.pg_class_tblspc_relfilenode_index IN ACCESS SHARE MODE NOWAIT");
switch (PQresultStatus(res))
{
case PGRES_COMMAND_OK:
retval = true;
break;
case PGRES_FATAL_ERROR:
sqlstate = PQresultErrorField(res, PG_DIAG_SQLSTATE);
if (sqlstate &&
strcmp(sqlstate, ERRCODE_WRONG_OBJECT_TYPE) == 0)
{
retval = false;
break;
}
else if (sqlstate &&
(strcmp(sqlstate, ERRCODE_LOCK_NOT_AVAILABLE) == 0 ||
strcmp(sqlstate, ERRCODE_INSUFFICIENT_PRIVILEGE) == 0))
{
retval = true;
break;
}
/* else, falls through */
default:
warn_or_exit_horribly(AH, "LOCK TABLE failed for \"%s\": %s",
"pg_catalog.pg_class_tblspc_relfilenode_index",
PQerrorMessage(AH->connection));
retval = false; /* not reached */
break;
}
PQclear(res);
CommitTransaction(AHX);
return retval;
}
void void
StartTransaction(Archive *AHX) StartTransaction(Archive *AHX)
{ {
......
...@@ -20,8 +20,6 @@ extern PGresult *ExecuteSqlQueryForSingleRow(Archive *fout, const char *query); ...@@ -20,8 +20,6 @@ extern PGresult *ExecuteSqlQueryForSingleRow(Archive *fout, const char *query);
extern void EndDBCopyMode(Archive *AHX, const char *tocEntryTag); extern void EndDBCopyMode(Archive *AHX, const char *tocEntryTag);
extern bool IsLockTableGeneric(Archive *AHX);
extern void StartTransaction(Archive *AHX); extern void StartTransaction(Archive *AHX);
extern void CommitTransaction(Archive *AHX); extern void CommitTransaction(Archive *AHX);
......
...@@ -1185,9 +1185,6 @@ setup_connection(Archive *AH, const char *dumpencoding, ...@@ -1185,9 +1185,6 @@ setup_connection(Archive *AH, const char *dumpencoding,
ExecuteSqlStatement(AH, "SET row_security = off"); ExecuteSqlStatement(AH, "SET row_security = off");
} }
/* Detect whether LOCK TABLE can handle non-table relations */
AH->hasGenericLockTable = IsLockTableGeneric(AH);
/* /*
* Start transaction-snapshot mode transaction to dump consistent data. * Start transaction-snapshot mode transaction to dump consistent data.
*/ */
...@@ -6855,16 +6852,16 @@ getTables(Archive *fout, int *numTables) ...@@ -6855,16 +6852,16 @@ getTables(Archive *fout, int *numTables)
* assume our lock on the child is enough to prevent schema * assume our lock on the child is enough to prevent schema
* alterations to parent tables. * alterations to parent tables.
* *
* We only need to lock the relation for certain components; see * NOTE: it'd be kinda nice to lock other relations too, not only
* pg_dump.h * plain or partitioned tables, but the backend doesn't presently
* allow that.
* *
* On server versions that support it, we lock all relations not just * We only need to lock the table for certain components; see
* plain tables. * pg_dump.h
*/ */
if (tblinfo[i].dobj.dump && if (tblinfo[i].dobj.dump &&
(fout->hasGenericLockTable || (tblinfo[i].relkind == RELKIND_RELATION ||
tblinfo[i].relkind == RELKIND_PARTITIONED_TABLE || tblinfo->relkind == RELKIND_PARTITIONED_TABLE) &&
tblinfo[i].relkind == RELKIND_RELATION) &&
(tblinfo[i].dobj.dump & DUMP_COMPONENTS_REQUIRING_LOCK)) (tblinfo[i].dobj.dump & DUMP_COMPONENTS_REQUIRING_LOCK))
{ {
resetPQExpBuffer(query); resetPQExpBuffer(query);
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment