Ank*_*iya 12 sql database string postgresql polymorphism
我有一个查询,输出为
无法确定多态类型,因为输入的类型为"未知"
查询:
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;
Run Code Online (Sandbox Code Playgroud)
我有一个postgres数据库
Cra*_*ger 22
这里的问题是'' as name实际上没有为值指定类型.这是unknown类型,PostgreSQL通常会推断出真正的类型,例如你要插入的列或者传递给它的函数.
在这种情况下,您将它传递给array_agg,这是一个多态函数.它可以接受伪类型的输入anyelement,这实际上只是意味着"在运行时计算出来".
PostgreSQL仍然可以解决它,除了array_to_string实际上并没有text[]输入.它需要anyarray- 另一种多态类型,如anyelement数组.
所以查询中没有任何内容可以告诉PostgreSQL它''是什么类型的.它可能猜到你的意思text,但它有点太挑剔了.所以它抱怨.该问题简化为:
regress=> SELECT array_to_string(array_agg(''), ',');
ERROR: could not determine polymorphic type because input has type "unknown"
Run Code Online (Sandbox Code Playgroud)
要解决此问题,请编写一个类型文字:
TEXT '' AS name
Run Code Online (Sandbox Code Playgroud)
或使用演员表:
CAST('' AS text) AS name
Run Code Online (Sandbox Code Playgroud)
或PostgreSQL简写:
''::text
Run Code Online (Sandbox Code Playgroud)
例子:
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)
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
7410 次 |
| 最近记录: |