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');

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...