【发布时间】:2021-06-01 23:01:08
【问题描述】:
我的函数得到了结果
EXECUTE format('SELECT ARRAY (SELECT tvmid from "%s".tvmtable order by tvmid)', operatorName) INTO tvms;
给出格式为 {1,2,3} 的 mi tvm 数组。我需要它有一个字符串除以 ,所以我正在尝试
SELECT ARRAY_TO_STRING(tvms, ",") INTO res;
但是当我执行我的函数时出现错误
ERROR: column "," does not exist
如果有帮助,这就是我的全部功能
create or replace function getTVMList(operatorName varchar)
returns varchar as $$
declare
tvms varchar[];
res varchar;
begin
EXECUTE format('SELECT ARRAY (SELECT tvmid from "%s".tvmtable order by tvmid)', operatorName) INTO tvms;
SELECT ARRAY_TO_STRING(tvms, ",") INTO res;
return res;
end;
$$
language plpgsql;
【问题讨论】:
-
在这种情况下,也可以使用聚合函数
string_agg。它会更快、更简单、更易读。
标签: postgresql plpgsql string-constant