-
Notifications
You must be signed in to change notification settings - Fork 285
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
v5.2.3 fix replica indentity inheritance when using indexes
- Loading branch information
Showing
5 changed files
with
113 additions
and
9 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,4 +1,4 @@ | ||
default_version = '5.2.2' | ||
default_version = '5.2.3' | ||
comment = 'Extension to manage partitioned tables by time or ID' | ||
relocatable = false | ||
superuser = false |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,77 @@ | ||
|
||
CREATE OR REPLACE FUNCTION @extschema@.inherit_replica_identity (p_parent_schemaname text, p_parent_tablename text, p_child_tablename text) RETURNS void | ||
LANGUAGE plpgsql | ||
AS $$ | ||
DECLARE | ||
|
||
v_child_partition_index text; | ||
v_child_partition_oid oid; | ||
v_parent_oid oid; | ||
v_parent_replident char; | ||
v_parent_replident_index name; | ||
v_replident_string text; | ||
v_sql text; | ||
|
||
BEGIN | ||
|
||
/* | ||
* Set the given child table's replica identity to the same as the parent | ||
NOTE: Replication identity not automatically inherited as of PG16 (revisit in future versions) | ||
*/ | ||
|
||
SELECT c.oid | ||
, c.relreplident | ||
INTO v_parent_oid | ||
, v_parent_replident | ||
FROM pg_catalog.pg_class c | ||
JOIN pg_catalog.pg_namespace n ON c.relnamespace = n.oid | ||
WHERE n.nspname = p_parent_schemaname | ||
AND c.relname = p_parent_tablename; | ||
|
||
IF v_parent_replident = 'i' THEN | ||
|
||
SELECT c.relname | ||
INTO v_parent_replident_index | ||
FROM pg_catalog.pg_class c | ||
JOIN pg_catalog.pg_index i ON i.indexrelid = c.oid | ||
WHERE i.indrelid = v_parent_oid | ||
AND indisreplident; | ||
|
||
SELECT c.oid | ||
INTO v_child_partition_oid | ||
FROM pg_catalog.pg_class c | ||
JOIN pg_catalog.pg_namespace n ON c.relnamespace = n.oid | ||
WHERE n.nspname = p_parent_schemaname | ||
AND c.relname = p_child_tablename; | ||
|
||
SELECT partition_index.indexrelid::regclass::text | ||
INTO v_child_partition_index | ||
FROM pg_index parent_index -- parent index | ||
INNER JOIN pg_inherits index_inheritance ON (index_inheritance.inhparent=parent_index.indexrelid) -- parent partition index | ||
INNER JOIN pg_index partition_index ON (index_inheritance.inhrelid=partition_index.indexrelid) -- connection between parent and partition indexes | ||
INNER JOIN pg_class partition_table ON (partition_table.oid=partition_index.indrelid) -- connection between child table and child index | ||
WHERE partition_table.oid=v_child_partition_oid -- child partition table | ||
AND parent_index.indexrelid=v_parent_replident_index::regclass; -- parent partition index | ||
|
||
END IF; | ||
|
||
RAISE DEBUG 'inherit_replica_ident: v_parent_oid: %, v_parent_replident: %, v_parent_replident_index: %, v_child_partition_oid: %, v_child_partition_index: %', v_parent_oid, v_parent_replident, v_parent_replident_index, v_child_partition_oid, v_child_partition_index; | ||
|
||
IF v_parent_replident != 'd' THEN | ||
CASE v_parent_replident | ||
WHEN 'f' THEN v_replident_string := 'FULL'; | ||
WHEN 'i' THEN v_replident_string := format('USING INDEX %I', v_child_partition_index); | ||
WHEN 'n' THEN v_replident_string := 'NOTHING'; | ||
ELSE | ||
RAISE EXCEPTION 'inherit_replica_identity: Unknown replication identity encountered (%). Please report as a bug on pg_partman''s github', v_parent_replident; | ||
END CASE; | ||
v_sql := format('ALTER TABLE %I.%I REPLICA IDENTITY %s' | ||
, p_parent_schemaname | ||
, p_child_tablename | ||
, v_replident_string); | ||
RAISE DEBUG 'inherit_replica_identity: replident v_sql: %', v_sql; | ||
EXECUTE v_sql; | ||
END IF; | ||
|
||
END | ||
$$; |