2004-01-11 05:58:17 +01:00
|
|
|
--
|
|
|
|
-- Regression tests for schemas (namespaces)
|
|
|
|
--
|
2023-05-08 15:14:07 +02:00
|
|
|
-- set the whitespace-only search_path to test that the
|
|
|
|
-- GUC list syntax is preserved during a schema creation
|
|
|
|
SELECT pg_catalog.set_config('search_path', ' ', false);
|
|
|
|
set_config
|
|
|
|
------------
|
|
|
|
|
|
|
|
(1 row)
|
|
|
|
|
2018-03-15 19:00:31 +01:00
|
|
|
CREATE SCHEMA test_ns_schema_1
|
2004-01-11 05:58:17 +01:00
|
|
|
CREATE UNIQUE INDEX abc_a_idx ON abc (a)
|
|
|
|
CREATE VIEW abc_view AS
|
|
|
|
SELECT a+1 AS a, b+1 AS b FROM abc
|
|
|
|
CREATE TABLE abc (
|
|
|
|
a serial,
|
|
|
|
b int UNIQUE
|
|
|
|
);
|
2023-05-08 15:14:07 +02:00
|
|
|
-- verify that the correct search_path restored on abort
|
|
|
|
SET search_path to public;
|
|
|
|
BEGIN;
|
|
|
|
SET search_path to public, test_ns_schema_1;
|
|
|
|
CREATE SCHEMA test_ns_schema_2
|
|
|
|
CREATE VIEW abc_view AS SELECT c FROM abc;
|
|
|
|
ERROR: column "c" does not exist
|
|
|
|
LINE 2: CREATE VIEW abc_view AS SELECT c FROM abc;
|
|
|
|
^
|
|
|
|
COMMIT;
|
|
|
|
SHOW search_path;
|
|
|
|
search_path
|
|
|
|
-------------
|
|
|
|
public
|
|
|
|
(1 row)
|
|
|
|
|
|
|
|
-- verify that the correct search_path preserved
|
|
|
|
-- after creating the schema and on commit
|
|
|
|
BEGIN;
|
|
|
|
SET search_path to public, test_ns_schema_1;
|
|
|
|
CREATE SCHEMA test_ns_schema_2
|
|
|
|
CREATE VIEW abc_view AS SELECT a FROM abc;
|
|
|
|
SHOW search_path;
|
|
|
|
search_path
|
|
|
|
--------------------------
|
|
|
|
public, test_ns_schema_1
|
|
|
|
(1 row)
|
|
|
|
|
|
|
|
COMMIT;
|
|
|
|
SHOW search_path;
|
|
|
|
search_path
|
|
|
|
--------------------------
|
|
|
|
public, test_ns_schema_1
|
|
|
|
(1 row)
|
|
|
|
|
|
|
|
DROP SCHEMA test_ns_schema_2 CASCADE;
|
|
|
|
NOTICE: drop cascades to view test_ns_schema_2.abc_view
|
2004-01-11 05:58:17 +01:00
|
|
|
-- verify that the objects were created
|
|
|
|
SELECT COUNT(*) FROM pg_class WHERE relnamespace =
|
2018-03-15 19:00:31 +01:00
|
|
|
(SELECT oid FROM pg_namespace WHERE nspname = 'test_ns_schema_1');
|
2004-01-11 05:58:17 +01:00
|
|
|
count
|
|
|
|
-------
|
|
|
|
5
|
|
|
|
(1 row)
|
|
|
|
|
2018-03-15 19:00:31 +01:00
|
|
|
INSERT INTO test_ns_schema_1.abc DEFAULT VALUES;
|
|
|
|
INSERT INTO test_ns_schema_1.abc DEFAULT VALUES;
|
|
|
|
INSERT INTO test_ns_schema_1.abc DEFAULT VALUES;
|
|
|
|
SELECT * FROM test_ns_schema_1.abc;
|
2004-01-11 05:58:17 +01:00
|
|
|
a | b
|
|
|
|
---+---
|
|
|
|
1 |
|
|
|
|
2 |
|
|
|
|
3 |
|
|
|
|
(3 rows)
|
|
|
|
|
2018-03-15 19:00:31 +01:00
|
|
|
SELECT * FROM test_ns_schema_1.abc_view;
|
2004-01-11 05:58:17 +01:00
|
|
|
a | b
|
|
|
|
---+---
|
|
|
|
2 |
|
|
|
|
3 |
|
|
|
|
4 |
|
|
|
|
(3 rows)
|
|
|
|
|
2018-03-15 19:00:31 +01:00
|
|
|
ALTER SCHEMA test_ns_schema_1 RENAME TO test_ns_schema_renamed;
|
2013-12-11 21:45:15 +01:00
|
|
|
SELECT COUNT(*) FROM pg_class WHERE relnamespace =
|
2018-03-15 19:00:31 +01:00
|
|
|
(SELECT oid FROM pg_namespace WHERE nspname = 'test_ns_schema_1');
|
2013-12-11 21:45:15 +01:00
|
|
|
count
|
|
|
|
-------
|
|
|
|
0
|
|
|
|
(1 row)
|
|
|
|
|
2012-10-04 01:47:11 +02:00
|
|
|
-- test IF NOT EXISTS cases
|
2018-03-15 19:00:31 +01:00
|
|
|
CREATE SCHEMA test_ns_schema_renamed; -- fail, already exists
|
|
|
|
ERROR: schema "test_ns_schema_renamed" already exists
|
|
|
|
CREATE SCHEMA IF NOT EXISTS test_ns_schema_renamed; -- ok with notice
|
|
|
|
NOTICE: schema "test_ns_schema_renamed" already exists, skipping
|
|
|
|
CREATE SCHEMA IF NOT EXISTS test_ns_schema_renamed -- fail, disallowed
|
2012-10-04 01:47:11 +02:00
|
|
|
CREATE TABLE abc (
|
|
|
|
a serial,
|
|
|
|
b int UNIQUE
|
|
|
|
);
|
|
|
|
ERROR: CREATE SCHEMA IF NOT EXISTS cannot include schema elements
|
2012-10-04 23:14:59 +02:00
|
|
|
LINE 2: CREATE TABLE abc (
|
|
|
|
^
|
2018-03-15 19:00:31 +01:00
|
|
|
DROP SCHEMA test_ns_schema_renamed CASCADE;
|
2008-06-11 23:53:49 +02:00
|
|
|
NOTICE: drop cascades to 2 other objects
|
2018-03-15 19:00:31 +01:00
|
|
|
DETAIL: drop cascades to table test_ns_schema_renamed.abc
|
|
|
|
drop cascades to view test_ns_schema_renamed.abc_view
|
2004-01-11 05:58:17 +01:00
|
|
|
-- verify that the objects were dropped
|
|
|
|
SELECT COUNT(*) FROM pg_class WHERE relnamespace =
|
2018-03-15 19:00:31 +01:00
|
|
|
(SELECT oid FROM pg_namespace WHERE nspname = 'test_ns_schema_renamed');
|
2004-01-11 05:58:17 +01:00
|
|
|
count
|
|
|
|
-------
|
|
|
|
0
|
|
|
|
(1 row)
|
|
|
|
|