如何解决在 PL/pgSQL 中迭代 integer[]
DO
$do$
DECLARE
a integer[] := array[1,2,3];
i integer; -- int, not bigint
BEGIN
FOR i IN 1 .. array_upper(a, 1)
LOOP
RAISE NOTICE '%', a[i]; -- single quotes
END LOOP;
END
$do$;
或者FOREACH在 Postgresql 9.1 或更高版本中更简单:
FOREACH i IN ARRAY a
LOOP
RAISE NOTICE '%', i;
END LOOP;
解决方法
我正在尝试integer[]在 plpgsql 函数中遍历整数数组 ( )。像这样的东西:
declare
a integer[] = array[1,2,3];
i bigint;
begin
for i in a
loop
raise notice "% ",i;
end loop;
return true;
end
在我的实际用例中,整数数组a作为参数传递给函数。我收到此错误:
ERROR: syntax error at or near "$1"
LINE 1: $1
如何正确循环数组?
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。