निम्नलिखित कोड आपको SYS_REFCURSOR
का चर प्राप्त करने में मदद कर सकता है Oracle अनाम ब्लॉक से।
हमें कुछ प्रमुख विवरणों पर ध्यान देना चाहिए:
- कक्षा
groovy.sql.Sql
संगतOutParameter
नहीं है और हम इसे मैन्युअल रूप सेCURSOR_PARAMETER
. के रूप में बनाते हैं और इसेsql.call
. पर पास करें विधि - मान लें कि ब्लॉक
{call DECLARE
. से शुरू होता है औरEND }
. के साथ समाप्त होता है END के बाद अर्धविराम के बिना। अन्यथा हम एक खराब पहचानने योग्यSQLException
प्राप्त कर सकते हैं चेहरे पर। - प्रश्न चिह्न
?
sqlString
के अंदर पैरामीटर बाइंडिंग के लिए स्थान हैं। बाइंडिंग को प्राकृतिक क्रम मेंparametersList
. से मान लेते हुए बनाया जाता है .- इस उदाहरण में हमारे पास केवल बाध्यकारी है, इसलिए
?
मान कोOUT
मानकर CURSOR_PARAMETER के साथ आबद्ध हो जाता है पारित प्रकार का पैरामीटर;
- इस उदाहरण में हमारे पास केवल बाध्यकारी है, इसलिए
sql.call
. के बाद केवल एक ही प्रवेश बंद होता है औरResultSet rs
कर्सर की पंक्तियाँ प्रदान करेंmy_cur
अनाम ब्लॉक में घोषित।- हम
sqlString
को सरल बना सकते हैंSYS_REFCURSOR
returning लौटाने वाले फ़ंक्शन का उपयोग करकेOUT
. के साथ एक प्रक्रिया के बजाय पैरामीटर। तो यह कुछ इस तरह दिख सकता है"{call BEGIN ? := MY_FUNC(); END}"
या यहां तक कि"{? = call MY_FUNC()}"
import groovy.sql.OutParameter
import groovy.sql.Sql
import oracle.jdbc.OracleTypes
import java.sql.ResultSet
def driver = 'oracle.jdbc.driver.OracleDriver'
def sql = Sql.newInstance('jdbc:oracle:thin:@my-server:1521:XXX', 'usr', 'psw', driver)
// special OutParameter for cursor type
OutParameter CURSOR_PARAMETER = new OutParameter() {
public int getType() {
return OracleTypes.CURSOR;
}
};
// look at some ceremonial wrappers around anonymous block
String sqlString = """{call
DECLARE
my_cur SYS_REFCURSOR;
BEGIN
STORED_PROCEDURE_NAME(my_cur);
? := my_cur;
END
}
""";
// the order of elements matches the order of bindings
def parametersList = [CURSOR_PARAMETER];
// rs contains the result set of cursor my_cur
sql.call(sqlString, parametersList) { ResultSet rs ->
while (rs.next()) {
println rs.getString("my_column")
}
};
पी.एस. और सवाल के लिए धन्यवाद।