Đoạn mã sau có thể giúp bạn lấy biến của SYS_REFCURSOR
từ khối ẩn danh Oracle.
Chúng ta nên tập trung vào một số chi tiết chính:
- Lớp
groovy.sql.Sql
không cóOutParameter
tương ứng và chúng tôi đặt nó theo cách thủ công làCURSOR_PARAMETER
và chuyển nó tớisql.call
phương pháp - Hãy xem xét rằng khối bắt đầu bằng
{call DECLARE
và kết thúc bằngEND }
không có dấu chấm phẩy sau END. Nếu không, chúng tôi có thể nhận đượcSQLException
kém nhận biết vào mặt. - Các dấu chấm hỏi
?
bên trongsqlString
là nơi cho các ràng buộc tham số. Các ràng buộc được thực hiện theo thứ tự tự nhiên lấy các giá trị từparametersList
.- Trong ví dụ này, chúng tôi có liên kết duy nhất, vì vậy
?
liên kết với CURSOR_PARAMETER coi giá trị làOUT
tham số của kiểu đã truyền;
- Trong ví dụ này, chúng tôi có liên kết duy nhất, vì vậy
- Chỉ có một lần nhập để đóng sau
sql.call
vàResultSet rs
cung cấp các hàng con trỏmy_cur
được khai báo trong khối ẩn danh. - Chúng tôi có thể đơn giản hóa
sqlString
bằng cách sử dụng một hàm trả vềSYS_REFCURSOR
bỏ sót một thủ tục vớiOUT
tham số. Vì vậy, nó có thể giống như thế này"{call BEGIN ? := MY_FUNC(); END}"
hoặc thậm chí"{? = 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")
}
};
P.S. Và cảm ơn bạn vì câu hỏi.