下記のようなカーソルを返すパッケージがあったとします。
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.?????はないでしょうか?
いろいろ調べたのですが手に負えず。
どなたか教えてください。
No.1ベストアンサー
- 回答日時:
まず、ご記入のソースは正しいでしょうか?
>sqlStr := 'OPEN CU FOR SELECT * FROM テーブル WHERE 条件 = ' || in条件;
のin条件はシングルクォーテンションでくくらなければSQL文としては構文エラーです。
別案ですが、CREATE OR REPLACE VIEWを作成し、忘れちゃったんですが作成したVIEWに対して条件設定があとで出来たはずです。m( )m
お返事ありがとうございます。
ちょっと私のスキルでは手に負えなくなりました。
勉強して出直してきます。
ありがとうございました。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・人生のプチ美学を教えてください!!
- ・10秒目をつむったら…
- ・あなたの習慣について教えてください!!
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・【大喜利】【投稿~9/18】 おとぎ話『桃太郎』の知られざるエピソード
- ・街中で見かけて「グッときた人」の思い出
- ・「一気に最後まで読んだ」本、教えて下さい!
- ・幼稚園時代「何組」でしたか?
- ・激凹みから立ち直る方法
- ・1つだけ過去を変えられるとしたら?
- ・【あるあるbot連動企画】あるあるbotに投稿したけど採用されなかったあるある募集
- ・【あるあるbot連動企画】フォロワー20万人のアカウントであなたのあるあるを披露してみませんか?
- ・映画のエンドロール観る派?観ない派?
- ・海外旅行から帰ってきたら、まず何を食べる?
- ・誕生日にもらった意外なもの
- ・天使と悪魔選手権
- ・ちょっと先の未来クイズ第2問
- ・【大喜利】【投稿~9/7】 ロボットの住む世界で流行ってる罰ゲームとは?
- ・推しミネラルウォーターはありますか?
- ・都道府県穴埋めゲーム
- ・この人頭いいなと思ったエピソード
- ・準・究極の選択
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
データベースファイル(.db)を開...
-
警察はスマホに保存した動画や...
-
Access フォーム上でコンボボッ...
-
帳票フォームでのあるコンボボ...
-
エクセルのフィルタ抽出が固まる
-
DBエラーを解決したい
-
私はシステム会社に務めている...
-
DocuWorksでの印刷
-
googleフォームでインストール...
-
式を簡単にしてください。ACCES...
-
ITパスポートについての質問で...
-
更新クエリをリンクデータベー...
-
CSVファイルでテキストの改行の...
-
ACCESSのSQLで、NULLかNULLでな...
-
Accessを開きなおすとテキスト...
-
Excelフィルタ抽出で「検索して...
-
顧客データベースを作る場合、...
-
マイクロソフトAccessでsqlのas...
-
情報整理するのに、「 Fullfree...
-
レコード数のカウント
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
PL/SQLカーソルの2重FORループ...
-
PL/SQLでのSQL文法
-
カーソル定義での条件分岐
-
Texの枠囲み調節
-
自動連番でカラムを更新したい
-
PL/SQLにて、マスタから取得し...
-
PL/SQL カーソルのFROM句にカー...
-
カーソルフェッチにて、最終レ...
-
ORA-00904:無効な識別子の回避...
-
カーソルループ内部でログを出力
-
T-SQLのカーソルで
-
PL/SQLで
-
PL/SQLのOPEN cursor_name FOR...
-
PL/SQLでカーソルを指定する方法
-
PL/SQLでの配列についてetc
-
PL/SQLでFORの働き
-
[Oracle9i]PL/SQLでFETCHしても...
-
同一表に同一データがある場合...
-
PL/SQL)Functionの引数(文字列...
-
【PL/SQL】CURSOR ・・・ IS SE...
おすすめ情報