From: | Stephan Szabo <sszabo(at)megazone23(dot)bigpanda(dot)com> |
---|---|
To: | "Tony G(dot) Harris" <tgharris_1(at)juno(dot)com> |
Cc: | <pgsql-sql(at)postgresql(dot)org> |
Subject: | Re: Trouble porting a Oracle PL/SQL procedure to PL/pgSQL |
Date: | 2003-06-17 02:17:57 |
Message-ID: | 20030616191549.W78774-100000@megazone23.bigpanda.com |
Views: | Raw Message | Whole Thread | Download mbox | Resend email |
Thread: | |
Lists: | 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).
From | Date | Subject | |
---|---|---|---|
Next Message | ko | 2003-06-17 02:56:38 | select date range? |
Previous Message | Tony G. Harris | 2003-06-17 01:57:42 | Trouble porting a Oracle PL/SQL procedure to PL/pgSQL |