小编典典

由于输入的类型为“未知”,因此无法确定多态类型。

sql

我有一个查询,输出为

无法确定多态类型,因为输入的类型为“未知”

询问 :

select ( array_to_string(array_agg(name), ', '))::text as name,path 
from(select 'fullpath' as Path,null as id,'' as name 
     from tblabc where key = 'key1' and value = '1' 
    ) as e 
group by path;

我有一个 postgres 数据库


阅读 233

收藏
2021-04-22

共1个答案

小编典典

这里的问题是'' as name实际上没有为值指定类型。这是unknown类型,PostgreSQL通常从诸如您将其插入哪一列或将其传递给什么函数之类的东西推断出真实类型。

在这种情况下,将其传递给array_agg,这是一个 多态
函数。它可以接受伪类型的输入anyelement,这实际上只是意味着“在运行时将其数字化”。

PostgreSQL仍然会解决这个问题,只是array_to_string实际上并不需要atext[]作为输入。它需要anyarray-另一个多态类型,例如anyelement数组。

因此查询中没有任何内容可以告诉PostgreSQL是什么类型''。可能会猜到您的意思text,但这有点过于挑剔。因此,它抱怨。该问题可简化为:

regress=> SELECT array_to_string(array_agg(''), ',');
ERROR:  could not determine polymorphic type because input has type "unknown"

要解决此问题,请编写一个带类型的文字:

TEXT '' AS name

或使用演员表:

CAST('' AS text) AS name

或PostgreSQL速记:

''::text

例子:

regress=> SELECT array_to_string(array_agg(TEXT ''), ',');
 array_to_string 
-----------------

(1 row)

regress=> SELECT array_to_string(array_agg(''::text), ',');
 array_to_string 
-----------------

(1 row)

regress=> SELECT array_to_string(array_agg(CAST('' AS text)), ',');
 array_to_string 
-----------------

(1 row)
2021-04-22