在plpgsql中循环遍历数组维度

时间:2012-03-20 08:21:47

标签: arrays postgresql multidimensional-array for-loop plpgsql

在plpgsql中,我想从二维数组中逐个获取数组内容。

DECLARE
  m varchar[];
  arr varchar[][] := array[['key1','val1'],['key2','val2']];
BEGIN
  for m in select arr
  LOOP
    raise NOTICE '%',m;
  END LOOP;
END;

但上面的代码返回:

{{key1,val1},{key2,val2}}

在一行。我希望能够循环并调用另一个带有以下参数的函数:

another_func(key1,val1)

1 个答案:

答案 0 :(得分:94)

由于PostgreSQL 9.1 ,方便的FOREACH

DO
$do$
DECLARE
   m   varchar[];
   arr varchar[] := array[['key1','val1'],['key2','val2']];
BEGIN
   FOREACH m SLICE 1 IN ARRAY arr
   LOOP
      RAISE NOTICE 'another_func(%,%)',m[1], m[2];
   END LOOP;
END
$do$

旧版本的解决方案

DO
$do$
DECLARE
   arr varchar[] := '{{key1,val1},{key2,val2}}';
BEGIN
   FOR i IN array_lower(arr, 1) .. array_upper(arr, 1)
   LOOP
      RAISE NOTICE 'another_func(%,%)',arr[i][1], arr[i][2];
   END LOOP;
END
$do$

此外,PostgreSQL类型系统的varchar[]varchar[][]之间没有区别。我会更详细地解释here

DO语句至少需要PostgreSQL 9.0,LANGUAGE plpgsql是默认语句(因此您可以省略声明)。