psql – variabile di ciclo di loop sopra le righe deve essere un record o di una riga variabile o di un elenco di variabili scalari

Qui è il mio semplice anonimo blocco di codice:

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;
$$;

Quando ho eseguito:

psql -f test.sql

Ottengo questo errore:

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
            ^
InformationsquelleAutor Richard Knop | 2013-04-11



One Reply
  1. 64

    Risolto io, meh:

    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;
    $$;

Lascia un commento