微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

如何在 plpgsql 中从数组创建字符串

如何解决如何在 plpgsql 中从数组创建字符串

我的函数得到了结果

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;

解决方法

双引号引用列名。

您必须将逗号放入单引号而不是双引号中:','

 SELECT ARRAY_TO_STRING(tvms,',') INTO res;

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。