【问题标题】:Iterating over integer[] in PL/pgSQL在 PL/pgSQL 中迭代 integer[]
【发布时间】:2012-04-30 03:50:07
【问题描述】:

我试图在 plpgsql 函数中循环一个整数数组 (integer[])。像这样的:

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

如何正确循环遍历数组?

【问题讨论】:

    标签: arrays postgresql loops plpgsql postgresql-8.4


    【解决方案1】:
    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$;
    

    或者在 PostgreSQL 9.1 或更高版本中使用FOREACH 更简单:

       FOREACH i IN ARRAY a
       LOOP 
          RAISE NOTICE '%', i;
       END LOOP;
    

    多维数组见:

    但是,使用 generate_series()unnest() 的基于集合的解决方案通常比在大集合上循环更快。基本示例:

    搜索标签 了解更多信息。

    【讨论】:

    • 现在我将数组传递给函数 f(array[1,2,3,4]) 有没有更好的方法将数组传递给函数?
    • f('{1,2,3,4}'::int[])另一种方式。更好的? - 你决定!
    • "i" 是值,而不是索引
    猜你喜欢
    • 2019-05-11
    • 1970-01-01
    • 2017-05-07
    • 1970-01-01
    • 1970-01-01
    • 2012-08-22
    • 1970-01-01
    • 2022-01-09
    相关资源
    最近更新 更多