Postgresql psql-行上循环的循环变量必须是记录、行变量或标量变量列表

Postgresql psql-行上循环的循环变量必须是记录、行变量或标量变量列表,postgresql,psql,Postgresql,Psql,以下是我的简单匿名代码块: do $$ declare foo varchar(50) := ''; begin for a in select a from (values('foo'), ('bar'), ('fooBar')) s(a) loop foo := a; print foo; end loop; end; $$; 当我运行它时: psql -f test.sql 我得到这个错误: psql:test.s

以下是我的简单匿名代码块:

do $$
  declare foo varchar(50) := '';
  begin
    for a in
      select a from (values('foo'), ('bar'), ('fooBar')) s(a)
    loop
      foo := a;
      print foo;
    end loop;
  end;
$$;
当我运行它时:

psql -f test.sql
我得到这个错误:

psql:test.sql:11: ERROR:  loop variable of loop over rows must be a record or row variable or list of scalar variables
LINE 4:     for a in
            ^

我自己解决的,嗯。需要在新记录中声明

do $$
  declare
    arow record;
    foo varchar(50);
  begin
    for arow in
      select a from (values('foo'), ('bar'), ('fooBar')) s(a)
    loop
      foo := arow.a;
      RAISE NOTICE 'Calling cs_create_job(%)', foo;
    end loop;
  end;
$$;

谢谢你救了我一天。你能不能把那个s(a)去掉,它让我困惑了一会儿:(