Re: PLpgSQL FOR IN EXECUTE question

Поиск
Список
Период
Сортировка
От Tom Lane
Тема Re: PLpgSQL FOR IN EXECUTE question
Дата
Msg-id 23283.1036692091@sss.pgh.pa.us
обсуждение исходный текст
Ответ на PLpgSQL FOR IN EXECUTE question  (Christoph Haller <ch@rodos.fzk.de>)
Список pgsql-sql
Christoph Haller <ch@rodos.fzk.de> writes:
> Consider the following PLpgSQL code fragment
> FOR this_record IN
> EXECUTE ''SELECT ''
>         || quote_ident($1)
>         || ''FROM ''
>         || quote_ident($2)
> LOOP
>     list := list || '', '' || this_record.$1 ;
> END LOOP;

> As expected, accessing a field via this_record.$1
> does not work.
> Can it be done otherwise?

FOR this_record IN
EXECUTE ''SELECT ''       || quote_ident($1)       || '' AS foo FROM ''       || quote_ident($2)
LOOP   list := list || '', '' || this_record.foo ;
END LOOP;

There is still another gotcha here though: the datatype of foo had
better remain the same every time, else the cached query plan for 
the concatenation will fail.  Explicitly casting to text in the
EXECUTE'd SELECT might be a good idea:

EXECUTE ''SELECT CAST(''       || quote_ident($1)       || '' AS TEXT) AS foo FROM ''       || quote_ident($2)
        regards, tom lane


В списке pgsql-sql по дате отправления:

Предыдущее
От: Joe Conway
Дата:
Сообщение: Re: Generating a cross tab (pivot table)
Следующее
От: Jeff Boes
Дата:
Сообщение: Quartile (etc) ranking in a SQL statement?