From: Robert Haas Date: Fri, 22 Jul 2011 20:15:43 +0000 (-0400) Subject: Unbreak unlogged tables. X-Git-Tag: REL9_2_BETA1~1365 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=6f1be5a67a758499beab0082b6e63b3040913268;p=postgresql Unbreak unlogged tables. I broke this in commit 5da79169d3e9f0fab47da03318c44075b3f824c5, which was obviously insufficiently well tested. Add some regression tests in the hope of making future slip-ups more likely to be noticed. --- diff --git a/src/backend/catalog/namespace.c b/src/backend/catalog/namespace.c index dec608c907..2386a89435 100644 --- a/src/backend/catalog/namespace.c +++ b/src/backend/catalog/namespace.c @@ -506,9 +506,10 @@ RangeVarAdjustRelationPersistence(RangeVar *newRelation, Oid nspid) errmsg("cannot create relations in temporary schemas of other sessions"))); break; default: - ereport(ERROR, - (errcode(ERRCODE_INVALID_TABLE_DEFINITION), - errmsg("only temporary relations may be created in temporary schemas"))); + if (isAnyTempNamespace(nspid)) + ereport(ERROR, + (errcode(ERRCODE_INVALID_TABLE_DEFINITION), + errmsg("only temporary relations may be created in temporary schemas"))); } } diff --git a/src/test/regress/expected/create_table.out b/src/test/regress/expected/create_table.out index 62010a1482..b1dedd469d 100644 --- a/src/test/regress/expected/create_table.out +++ b/src/test/regress/expected/create_table.out @@ -204,3 +204,14 @@ CREATE TABLE IF NOT EXISTS test_tsvector( t text ); NOTICE: relation "test_tsvector" already exists, skipping +CREATE UNLOGGED TABLE unlogged1 (a int); -- OK +INSERT INTO unlogged1 VALUES (42); +CREATE UNLOGGED TABLE public.unlogged2 (a int); -- also OK +CREATE UNLOGGED TABLE pg_temp.unlogged3 (a int); -- not OK +ERROR: only temporary relations may be created in temporary schemas +CREATE TABLE pg_temp.implicity_temp (a int); -- OK +CREATE TEMP TABLE explicitly_temp (a int); -- also OK +CREATE TEMP TABLE pg_temp.doubly_temp (a int); -- also OK +CREATE TEMP TABLE public.temp_to_perm (a int); -- not OK +ERROR: cannot create temporary relation in non-temporary schema +DROP TABLE unlogged1, public.unlogged2; diff --git a/src/test/regress/sql/create_table.sql b/src/test/regress/sql/create_table.sql index e622b1f0f5..c1b2acf94d 100644 --- a/src/test/regress/sql/create_table.sql +++ b/src/test/regress/sql/create_table.sql @@ -240,3 +240,13 @@ CREATE TABLE IF NOT EXISTS test_tsvector( CREATE TABLE IF NOT EXISTS test_tsvector( t text ); + +CREATE UNLOGGED TABLE unlogged1 (a int); -- OK +INSERT INTO unlogged1 VALUES (42); +CREATE UNLOGGED TABLE public.unlogged2 (a int); -- also OK +CREATE UNLOGGED TABLE pg_temp.unlogged3 (a int); -- not OK +CREATE TABLE pg_temp.implicity_temp (a int); -- OK +CREATE TEMP TABLE explicitly_temp (a int); -- also OK +CREATE TEMP TABLE pg_temp.doubly_temp (a int); -- also OK +CREATE TEMP TABLE public.temp_to_perm (a int); -- not OK +DROP TABLE unlogged1, public.unlogged2;