如何解决Postgresql:为 SELECT 中的值分区表
我想在具有 UUID 值的列上使用 Postgresql 的声明性表分区。我希望它按 SELECT 返回的值进行分区。
CREATE TABLE foo (
id uuid NOT NULL,type_id uuid NOT NULL,-- other columns
PRIMARY KEY (id,type_id)
) PARTITION BY LIST (type_id);
CREATE TABLE foo_1 PARTITION OF foo
FOR VALUES IN (SELECT id FROM type_ids WHERE type_name = 'type1');
CREATE TABLE foo_2 PARTITION OF foo
FOR VALUES IN (SELECT id FROM type_ids WHERE type_name = 'type2');
我不想在 FOR VALUES IN ('uuid')
中使用特定的 UUID,因为 UUID 可能因环境(dev、qa、prod)而异。但是,Postgres 似乎不接受 SELECT
语法。有什么建议吗?
解决方法
我只想在创建表时评估 SELECT
你应该在问题中说清楚,而不是在评论中。
在这种情况下 - 如果这是一次性的,您可以使用动态 SQL,例如包装成一个过程
create procedure create_partition(p_part_name text,p_type_name text)
as
$$
declare
l_sql text;
l_id uuid;
begin
select id
into l_id
from type_ids
where type_name = p_type_name;
l_sql := format('CREATE TABLE %I PARTITION OF foo FOR VALUES IN (%L)',p_part_name,l_id);
execute l_sql;
end;
$$
language plpgsql;
然后你可以这样做:
call create_partition('foo_1','type1');
call create_partition('foo_2','type2');
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。