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

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).

In response to

Responses

Browse pgsql-sql by date

  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