mirror of
https://github.com/postgres/postgres.git
synced 2025-06-23 14:01:44 +03:00
Add partitioned table support to sepgsql
The new partitioned table capability added a new relkind, namely RELKIND_PARTITIONED_TABLE. Update sepgsql to treat this new relkind exactly the same way it does RELKIND_RELATION. In addition, add regression test coverage for partitioned tables. Issue raised by Stephen Frost and initial patch by Mike Palmiotto. Review by Tom Lane and Robert Haas, and editorializing by me. Discussion: https://postgr.es/m/flat/623bcaae-112e-ced0-8c22-a84f75ae0c53%40joeconway.com
This commit is contained in:
@ -32,6 +32,15 @@ CREATE TABLE regtest_table_2 (c text) inherits (regtest_table_1);
|
||||
|
||||
CREATE TABLE regtest_table_3 (x int primary key, y text);
|
||||
|
||||
---
|
||||
-- partitioned table parent
|
||||
CREATE TABLE regtest_ptable_1 (o int, p text) PARTITION BY RANGE (o);
|
||||
|
||||
-- partitioned table children
|
||||
CREATE TABLE regtest_ptable_1_ones PARTITION OF regtest_ptable_1 FOR VALUES FROM ('0') TO ('10');
|
||||
CREATE TABLE regtest_ptable_1_tens PARTITION OF regtest_ptable_1 FOR VALUES FROM ('10') TO ('100');
|
||||
---
|
||||
|
||||
CREATE SEQUENCE regtest_seq_1;
|
||||
|
||||
CREATE VIEW regtest_view_1 AS SELECT * FROM regtest_table_1 WHERE a > 0;
|
||||
@ -55,6 +64,8 @@ ALTER SCHEMA regtest_schema_1 OWNER TO regress_sepgsql_test_user;
|
||||
ALTER SCHEMA regtest_schema_1 OWNER TO regress_sepgsql_test_user;
|
||||
ALTER TABLE regtest_table_1 OWNER TO regress_sepgsql_test_user;
|
||||
ALTER TABLE regtest_table_1 OWNER TO regress_sepgsql_test_user;
|
||||
ALTER TABLE regtest_ptable_1 OWNER TO regress_sepgsql_test_user;
|
||||
ALTER TABLE regtest_ptable_1_ones OWNER TO regress_sepgsql_test_user;
|
||||
ALTER SEQUENCE regtest_seq_1 OWNER TO regress_sepgsql_test_user;
|
||||
ALTER SEQUENCE regtest_seq_1 OWNER TO regress_sepgsql_test_user;
|
||||
ALTER VIEW regtest_view_1 OWNER TO regress_sepgsql_test_user;
|
||||
@ -66,6 +77,8 @@ ALTER FUNCTION regtest_func_1(text) OWNER TO regress_sepgsql_test_user;
|
||||
-- ALTER xxx SET SCHEMA
|
||||
--
|
||||
ALTER TABLE regtest_table_1 SET SCHEMA regtest_schema_2;
|
||||
ALTER TABLE regtest_ptable_1 SET SCHEMA regtest_schema_2;
|
||||
ALTER TABLE regtest_ptable_1_ones SET SCHEMA regtest_schema_2;
|
||||
ALTER SEQUENCE regtest_seq_1 SET SCHEMA regtest_schema_2;
|
||||
ALTER VIEW regtest_view_1 SET SCHEMA regtest_schema_2;
|
||||
ALTER FUNCTION regtest_func_1(text) SET SCHEMA regtest_schema_2;
|
||||
@ -76,6 +89,14 @@ ALTER FUNCTION regtest_func_1(text) SET SCHEMA regtest_schema_2;
|
||||
ALTER DATABASE sepgsql_test_regression_1 RENAME TO sepgsql_test_regression;
|
||||
ALTER SCHEMA regtest_schema_1 RENAME TO regtest_schema;
|
||||
ALTER TABLE regtest_table_1 RENAME TO regtest_table;
|
||||
|
||||
---
|
||||
-- partitioned table parent
|
||||
ALTER TABLE regtest_ptable_1 RENAME TO regtest_ptable;
|
||||
-- partitioned table child
|
||||
ALTER TABLE regtest_ptable_1_ones RENAME TO regtest_table_part;
|
||||
---
|
||||
|
||||
ALTER SEQUENCE regtest_seq_1 RENAME TO regtest_seq;
|
||||
ALTER VIEW regtest_view_1 RENAME TO regtest_view;
|
||||
ALTER FUNCTION regtest_func_1(text) RENAME TO regtest_func;
|
||||
@ -121,6 +142,50 @@ ALTER TABLE regtest_table_2 NO INHERIT regtest_table; -- not supported
|
||||
ALTER TABLE regtest_table_2 INHERIT regtest_table; -- not supported
|
||||
ALTER TABLE regtest_table SET TABLESPACE pg_default;
|
||||
|
||||
---
|
||||
-- partitioned table parent
|
||||
ALTER TABLE regtest_ptable ADD COLUMN d float;
|
||||
ALTER TABLE regtest_ptable DROP COLUMN d;
|
||||
ALTER TABLE regtest_ptable ALTER p SET DEFAULT 'abcd'; -- not supported by sepgsql
|
||||
ALTER TABLE regtest_ptable ALTER p SET DEFAULT 'XYZ'; -- not supported by sepgsql
|
||||
ALTER TABLE regtest_ptable ALTER p DROP DEFAULT; -- not supported by sepgsql
|
||||
ALTER TABLE regtest_ptable ALTER p SET NOT NULL;
|
||||
ALTER TABLE regtest_ptable ALTER p DROP NOT NULL;
|
||||
ALTER TABLE regtest_ptable ALTER p SET STATISTICS -1;
|
||||
ALTER TABLE regtest_ptable ALTER p SET (n_distinct = 999);
|
||||
ALTER TABLE regtest_ptable ALTER p SET STORAGE PLAIN;
|
||||
ALTER TABLE regtest_ptable ADD CONSTRAINT test_ck CHECK (p like '%abc%') NOT VALID; -- not supported by sepgsql
|
||||
ALTER TABLE regtest_ptable DROP CONSTRAINT test_ck; -- not supported by sepgsql
|
||||
|
||||
ALTER TABLE regtest_ptable SET WITH OIDS;
|
||||
ALTER TABLE regtest_ptable SET WITHOUT OIDS;
|
||||
ALTER TABLE regtest_ptable SET TABLESPACE pg_default;
|
||||
|
||||
-- partitioned table child
|
||||
ALTER TABLE regtest_table_part ALTER p SET DEFAULT 'abcd'; -- not supported by sepgsql
|
||||
ALTER TABLE regtest_table_part ALTER p SET DEFAULT 'XYZ'; -- not supported by sepgsql
|
||||
ALTER TABLE regtest_table_part ALTER p DROP DEFAULT; -- not supported by sepgsql
|
||||
ALTER TABLE regtest_table_part ALTER p SET NOT NULL;
|
||||
ALTER TABLE regtest_table_part ALTER p DROP NOT NULL;
|
||||
ALTER TABLE regtest_table_part ALTER p SET STATISTICS -1;
|
||||
ALTER TABLE regtest_table_part ALTER p SET (n_distinct = 999);
|
||||
ALTER TABLE regtest_table_part ALTER p SET STORAGE PLAIN;
|
||||
ALTER TABLE regtest_table_part ADD CONSTRAINT test_ck CHECK (p like '%abc%') NOT VALID; -- not supported by sepgsql
|
||||
ALTER TABLE regtest_table_part VALIDATE CONSTRAINT test_ck; -- not supported by sepgsql
|
||||
ALTER TABLE regtest_table_part DROP CONSTRAINT test_ck; -- not supported by sepgsql
|
||||
|
||||
CREATE TRIGGER regtest_part_test_trig BEFORE UPDATE ON regtest_table_part
|
||||
FOR EACH ROW EXECUTE PROCEDURE suppress_redundant_updates_trigger();
|
||||
|
||||
ALTER TABLE regtest_table_part DISABLE TRIGGER regtest_part_test_trig; -- not supported by sepgsql
|
||||
ALTER TABLE regtest_table_part ENABLE TRIGGER regtest_part_test_trig; -- not supported by sepgsql
|
||||
|
||||
ALTER TABLE regtest_table_part SET (fillfactor = 75);
|
||||
ALTER TABLE regtest_table_part RESET (fillfactor);
|
||||
|
||||
ALTER TABLE regtest_table_part SET TABLESPACE pg_default;
|
||||
---
|
||||
|
||||
ALTER VIEW regtest_view SET (security_barrier);
|
||||
|
||||
ALTER SEQUENCE regtest_seq INCREMENT BY 10 START WITH 1000;
|
||||
|
Reference in New Issue
Block a user