क्लासिक स्थिति सभी के पास है। आप अपनी सरणी या किसी चीज़ के आधार पर गतिशील रूप से एक क्वेरी स्ट्रिंग बना सकते हैं। और ओपन कर्सर के रूप में उपयोग करें। ।
DECLARE
v_mystring VARCHAR(50);
v_my_ref_cursor sys_refcursor;
in_string varchar2='''abc'',''bcd''';
id2 varchar2(10):='123';
myrecord tablename%rowtype;
BEGIN
v_mystring := 'SELECT a.*... from tablename a where name= :id2 and
id in('||in_string||')';
OPEN v_my_ref_cursor FOR v_mystring USING id2;
LOOP
FETCH v_my_ref_cursor INTO myrecord;
EXIT WHEN v_my_ref_cursor%NOTFOUND;
..
-- your processing
END LOOP;
CLOSE v_my_ref_cursor;
END;
IN क्लॉज अधिकतम 1000 वस्तुओं का समर्थन करता है। आप इसके बजाय शामिल होने के लिए किसी तालिका का उपयोग कर सकते हैं। वह तालिका एक Global Temporary Table(GTT)
हो सकती है जिसका डेटा उस विशेष सत्र के लिए दृश्यमान है।
फिर भी आप एक nested table
का उपयोग कर सकते हैं इसके लिए भी (जैसे PL/SQL तालिका)
TABLE()
एक पीएल/एसक्यूएल टेबल को एसक्यूएल समझने योग्य टेबल ऑब्जेक्ट (वास्तव में एक वस्तु) के रूप में परिवर्तित करेगा
इसका एक सरल उदाहरण नीचे दिया गया है।
CREATE TYPE pr AS OBJECT
(pr NUMBER);
/
CREATE TYPE prList AS TABLE OF pr;
/
declare
myPrList prList := prList ();
cursor lc is
select *
from (select a.*
from yourtable a
TABLE(CAST(myPrList as prList)) my_list
where
a.pr = my_list.pr
order by a.pr desc) ;
rec lc%ROWTYPE;
BEGIN
/*Populate the Nested Table, with whatever collection you have */
myPrList := prList ( pr(91),
pr(80));
/*
Sample code: for populating from your TABLE OF NUMBER type
FOR I IN 1..your_input_array.COUNT
LOOP
myPrList.EXTEND;
myPrList(I) := pr(your_input_array(I));
END LOOP;
*/
open lc;
loop
FETCH lc into rec;
exit when lc%NOTFOUND; -- Your Exit WHEN condition should be checked afte FETCH iyself!
dbms_output.put_line(rec.pr);
end loop;
close lc;
END;
/