From dbd2a9a23560ecf863e687cdece00b7bab4f1d67 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Guillermo=20Gonz=C3=A1lez=20de=20Ag=C3=BCero?= Date: Wed, 1 May 2024 18:40:33 +0200 Subject: [PATCH] Handle >64 characters partition names --- dbt/include/postgres/macros/adapters.sql | 10 ++++------ 1 file changed, 4 insertions(+), 6 deletions(-) diff --git a/dbt/include/postgres/macros/adapters.sql b/dbt/include/postgres/macros/adapters.sql index 4787ff24..b0e4b5dc 100644 --- a/dbt/include/postgres/macros/adapters.sql +++ b/dbt/include/postgres/macros/adapters.sql @@ -109,11 +109,7 @@ {% set existing_partitions_query %} select inhrelid::regclass::text as from_table_name, - replace( - inhrelid::regclass::text, - '{{ from_relation.schema }}.{{ from_relation.identifier }}', -- Current partition name - '{{ to_relation.identifier }}' -- New partition name - ) as to_table_name + regexp_substr(inhrelid::regclass::text, '[^_]*$') as partition_suffix -- Get the string after the last underscore from pg_catalog.pg_inherits where inhparent = '{{ from_relation.schema }}.{{ from_relation.identifier }}'::regclass; {% endset %} @@ -121,7 +117,9 @@ -- Rename the existing partitions {% for existing_partition in existing_partitions_results.rows %} - alter table {{ existing_partition["from_table_name"] }} rename to {{ existing_partition["to_table_name"] }}; + {%- set partition_relation = make_intermediate_relation(to_relation, existing_partition['partition_suffix']) %} + + alter table {{ existing_partition["from_table_name"] }} rename to {{ partition_relation.identifier }}; {% endfor %} {%- endcall %} {% endmacro %}