Question:
How do I get a result set from an Oracle Stored Procedure?
Answer:
A REF CURSOR is required to return a result set from a stored procedure. You will need to put the procedure in a package. To create a package use the following SQL command:
CREATE PACKAGE MYPKG IS TYPE CursorType IS REF CURSOR; END MyPkg;Then when you create the procedure:
CREATE PROCEDURE RETURN_RESULT_SET (oCursor IN OUT MyPkg.CursorType) AS BEGIN open oCursor for select * from SomeTable; END;In Delphi or C++Builder, set the TStoredProc parameter DataType as type ftCursor. At this point you should treat the TStoredProc component like a TQuery and use the Open method instead of ExecProc.
Last Modified: 12-APR-02