mirror of
https://git.postgresql.org/git/postgresql.git
synced 2024-10-06 01:37:01 +02:00
69 lines
2.7 KiB
MySQL
69 lines
2.7 KiB
MySQL
|
--
|
||
|
-- Tests for pg_partition_tree
|
||
|
--
|
||
|
SELECT * FROM pg_partition_tree(NULL);
|
||
|
|
||
|
-- Test table partition trees
|
||
|
CREATE TABLE ptif_test (a int, b int) PARTITION BY range (a);
|
||
|
CREATE TABLE ptif_test0 PARTITION OF ptif_test
|
||
|
FOR VALUES FROM (minvalue) TO (0) PARTITION BY list (b);
|
||
|
CREATE TABLE ptif_test01 PARTITION OF ptif_test0 FOR VALUES IN (1);
|
||
|
CREATE TABLE ptif_test1 PARTITION OF ptif_test
|
||
|
FOR VALUES FROM (0) TO (100) PARTITION BY list (b);
|
||
|
CREATE TABLE ptif_test11 PARTITION OF ptif_test1 FOR VALUES IN (1);
|
||
|
CREATE TABLE ptif_test2 PARTITION OF ptif_test
|
||
|
FOR VALUES FROM (100) TO (maxvalue);
|
||
|
|
||
|
-- Test index partition tree
|
||
|
CREATE INDEX ptif_test_index ON ONLY ptif_test (a);
|
||
|
CREATE INDEX ptif_test0_index ON ONLY ptif_test0 (a);
|
||
|
ALTER INDEX ptif_test_index ATTACH PARTITION ptif_test0_index;
|
||
|
CREATE INDEX ptif_test01_index ON ptif_test01 (a);
|
||
|
ALTER INDEX ptif_test0_index ATTACH PARTITION ptif_test01_index;
|
||
|
CREATE INDEX ptif_test1_index ON ONLY ptif_test1 (a);
|
||
|
ALTER INDEX ptif_test_index ATTACH PARTITION ptif_test1_index;
|
||
|
CREATE INDEX ptif_test11_index ON ptif_test11 (a);
|
||
|
ALTER INDEX ptif_test1_index ATTACH PARTITION ptif_test11_index;
|
||
|
CREATE INDEX ptif_test2_index ON ptif_test2 (a);
|
||
|
ALTER INDEX ptif_test_index ATTACH PARTITION ptif_test2_index;
|
||
|
|
||
|
-- List all tables members of the tree
|
||
|
SELECT relid, parentrelid, level, isleaf
|
||
|
FROM pg_partition_tree('ptif_test');
|
||
|
-- List tables from an intermediate level
|
||
|
SELECT relid, parentrelid, level, isleaf
|
||
|
FROM pg_partition_tree('ptif_test0') p
|
||
|
JOIN pg_class c ON (p.relid = c.oid);
|
||
|
-- List from leaf table
|
||
|
SELECT relid, parentrelid, level, isleaf
|
||
|
FROM pg_partition_tree('ptif_test01') p
|
||
|
JOIN pg_class c ON (p.relid = c.oid);
|
||
|
|
||
|
-- List all indexes members of the tree
|
||
|
SELECT relid, parentrelid, level, isleaf
|
||
|
FROM pg_partition_tree('ptif_test_index');
|
||
|
-- List indexes from an intermediate level
|
||
|
SELECT relid, parentrelid, level, isleaf
|
||
|
FROM pg_partition_tree('ptif_test0_index') p
|
||
|
JOIN pg_class c ON (p.relid = c.oid);
|
||
|
-- List from leaf index
|
||
|
SELECT relid, parentrelid, level, isleaf
|
||
|
FROM pg_partition_tree('ptif_test01_index') p
|
||
|
JOIN pg_class c ON (p.relid = c.oid);
|
||
|
|
||
|
DROP TABLE ptif_test;
|
||
|
|
||
|
-- A table not part of a partition tree works is the only member listed.
|
||
|
CREATE TABLE ptif_normal_table(a int);
|
||
|
SELECT relid, parentrelid, level, isleaf
|
||
|
FROM pg_partition_tree('ptif_normal_table');
|
||
|
DROP TABLE ptif_normal_table;
|
||
|
|
||
|
-- Views and materialized viewS cannot be part of a partition tree.
|
||
|
CREATE VIEW ptif_test_view AS SELECT 1;
|
||
|
CREATE MATERIALIZED VIEW ptif_test_matview AS SELECT 1;
|
||
|
SELECT * FROM pg_partition_tree('ptif_test_view');
|
||
|
SELECT * FROM pg_partition_tree('ptif_test_matview');
|
||
|
DROP VIEW ptif_test_view;
|
||
|
DROP MATERIALIZED VIEW ptif_test_matview;
|