Postgres将数组转换为自定义类型

时间:2019-12-02 19:03:57

标签: postgresql plpgsql postgresql-9.5 postgresql-11

我必须将varchar数组转换为自定义类型,但失败。

场景

CREATE TYPE foo AS (foo text[]);

SELECT ARRAY['TEST_ONE']::foo; -- fails with ERROR: cannot cast type text[] to foo

我实际上必须将此类型作为可选参数传递给函数,因此我必须将其默认值放在函数参数列表中。像这样

create function foo_func(par1 foo DEFAULT ARRAY['TEST_ONE']::foo) .... 但这由于上述问题而无法解决...

我们将不胜感激。.

1 个答案:

答案 0 :(得分:1)

很难猜测为什么有人会想通过这样一个奇怪的想法使自己的生活复杂化。无论如何,类型foo是具有单个text[]元素的复合类型,因此文字应如下所示:

SELECT ROW(ARRAY['TEST_ONE'])::foo;

也许domain会更方便:

create domain foo as text[];
select array['test_one']::foo;