こんにちはゲストさん。会員登録(無料)して質問・回答してみよう!

解決済みの質問

動的なSQLからカーソルを返す。

下記のようなカーソルを返すパッケージがあったとします。

CREATE OR REPLACE PACKAGE TEST AS
CURSOR C1 IS SELECT * FROM テーブル;
TYPE TC1 IS REF CURSOR RETURN C1%ROWTYPE;
PROCEDURE P_TEST(in条件 IN CHAR, CU OUT TC1);
END;

CREATE OR REPLACE PACKAGE BODY TEST IS
PROCEDURE P_TEST(in条件 IN CHAR, CU OUT TC1)
AS
sqlStr VARCHAR2(1000);
cur NUMBER;
r NUMBER;
BEGIN
cur := DBMS_SQL.OPEN_CURSOR;
sqlStr := 'OPEN CU FOR SELECT * FROM テーブル WHERE 条件 = ' || in条件;
DBMS_SQL.PARSE(cur, sqlStr, DBMS_SQL.NATIVE);
DBMS_SQL.DEFINE_COLUMN(cur, 1, CU);
r := DBMS_SQL.EXECUTE(cur);
DBMS_SQL.CLOSE_CURSOR(cur);
END;

SELECTした結果のカーソル(CU)をクライアントで取得したいのですけど
技術的に可能でしょうか?
ストアドのコンパイル時に→DBMS_SQL.DEFINE_COLUMN(cur, 1, CU);が
エラーとなります。
DBMS_SQL.DEFINE_COLUMNではカーソルタイプは取得できないとわっかたの
ですがカーソルを取得する為のDBMS_SQL.DEFINE_COLUMNにかわる
DBMS_SQL.?????はないでしょうか?
いろいろ調べたのですが手に負えず。
どなたか教えてください。

投稿日時 - 2003-03-07 21:37:14

QNo.492084

すぐに回答ほしいです

質問者が選んだベストアンサー

まず、ご記入のソースは正しいでしょうか?

>sqlStr := 'OPEN CU FOR SELECT * FROM テーブル WHERE 条件 = ' || in条件;

のin条件はシングルクォーテンションでくくらなければSQL文としては構文エラーです。

別案ですが、CREATE OR REPLACE VIEWを作成し、忘れちゃったんですが作成したVIEWに対して条件設定があとで出来たはずです。m( )m

投稿日時 - 2003-04-04 18:04:32

お礼

お返事ありがとうございます。
ちょっと私のスキルでは手に負えなくなりました。
勉強して出直してきます。
ありがとうございました。

投稿日時 - 2003-04-24 22:31:21

このQ&Aは役に立ちましたか?

0人が「このQ&Aが役に立った」と投票しています

回答(1)

あなたにオススメの質問