Re: Trouble porting a Oracle PL/SQL procedure to PL/pgSQL

Поиск
Список
Период
Сортировка
От Stephan Szabo
Тема Re: Trouble porting a Oracle PL/SQL procedure to PL/pgSQL
Дата
Msg-id 20030616191549.W78774-100000@megazone23.bigpanda.com
обсуждение исходный текст
Ответ на Trouble porting a Oracle PL/SQL procedure to PL/pgSQL  ("Tony G. Harris" <tgharris_1@juno.com>)
Ответы Re: Trouble porting a Oracle PL/SQL procedure to PL/pgSQL  (Tom Lane <tgl@sss.pgh.pa.us>)
Список pgsql-sql
On Mon, 16 Jun 2003, Tony G. Harris wrote:

> Hello.  I'm using PostgreSQL to learn SQL and SQL-based languages.  The
> text I'm using (SAMS Teach Yourself SQL in 21 Days, 3rd.ed.) references
> Oracle in its examples, though I can usually get PostgreSQL to work
> almost as well.
>
> Well, I'm almost to the end of the book and I'm trying to port some of
> the book's PL/SQL examples to PL/pgSQL, with mixed success.  In this
> case, I translated
>
> BEGIN
>         DECLARE
>                   UnknownPayType EXCEPTION;
>                   CURSOR pay_cursor IS
>                    SELECT name, pay_type, pay_rate, eff_date, sysdate,
> rowid
>                    FROM pay_table;
>                   IndRec pay_cursor%ROWTYPE;
>           . . .
> END;
> /
>
> to this:
>
> CREATE OR REPLACE FUNCTION update_pay() RETURNS VOID AS '
>          DECLARE
>           pay_cursor CURSOR IS
>            SELECT name, pay_type, pay_rate, eff_date, current_date, oid
>            FROM pay_table;
>           IndRec pay_cursor%ROWTYPE;
>           cOldDate DATE;
>         . . .
>         END;
> '
> LANGUAGE 'plpgsql';
>
> The problem is, when I call the function, I get:
>
> sql-practice=# select update_pay();
> ERROR:  pay_cursor: no such class
> WARNING:  plpgsql: ERROR during compile of update_pay near line 2
> WARNING:  plpgsql: ERROR during compile of update_pay near line 2
> ERROR:  pay_cursor: no such class
>
> I tried several ways of defining pay_cursor, with the same result.
> What am I to do?

I think it's complaining because you can't use pay_cursor%ROWTYPE.  Maybe
declaring IndRec as being of type record may work (don't know for
certain).




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

Предыдущее
От: "Tony G. Harris"
Дата:
Сообщение: Trouble porting a Oracle PL/SQL procedure to PL/pgSQL
Следующее
От: "ko"
Дата:
Сообщение: select date range?