Re: Ordering a record returned from a stored procedure

Поиск
Список
Период
Сортировка
От Stephan Szabo
Тема Re: Ordering a record returned from a stored procedure
Дата
Msg-id 20041018092408.N14426@megazone.bigpanda.com
обсуждение исходный текст
Ответ на Ordering a record returned from a stored procedure  ("Kent Anderson" <kenta@ezyield.com>)
Ответы Re: Ordering a record returned from a stored procedure - date issue
Список pgsql-sql
On Mon, 18 Oct 2004, Kent Anderson wrote:

> I am pulling a report from the database using a stored procedure but cannot
> get the information to return in a specific order unless I hardcode the
> order by clause.
>
> CREATE OR REPLACE FUNCTION submissionreport(INTEGER, DATE, TEXT) RETURNS
> setof submissionrec AS '
> DECLARE
>                 result submissionrec%rowtype;
>                 hmhmkey ALIAS for $1;
>                 submissiondate ALIAS for $2;
>                 sort ALIAS for $3;
>
> BEGIN
> RAISE NOTICE ''The sort order should be: %.'', sort;
> FOR result IN
>  SELECT
>     (..... select all necessary fields ...)
> FROM
>     (.... tables ...)
> WHERE
>     (... contraints)
>
> ORDER BY sort
> LOOP
>         RETURN next result;
> END LOOP;
>
>  RETURN result;
>
>
> END;
> ' LANGUAGE plpgsql;
>
> What am I missing? The returned data is ordered if the "Order By" clause has
> the values hard coded but doesn't seem to read the "sort" variable.

You're telling it to order by the value of the third argument, not the
value of the column with the name of the third argument.  I think right
now you'd need to use EXECUTE to put it in as if it were the expression to
sort on.



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

Предыдущее
От: "Kent Anderson"
Дата:
Сообщение: Ordering a record returned from a stored procedure
Следующее
От: beyaNet
Дата:
Сообщение: problems using phpPgAmin