我正在尝试从Java调用StoredProcedure,但是返回的结果始终为 false 。实际上,它必须返回100个记录。连接建立良好。
我有一个 存储过程 ,
PROCEDURE get_records ( grp1 IN a.name%TYPE DEFAULT NULL ,grp2 IN a.name%TYPE DEFAULT NULL ,grp3 IN a.name%TYPE DEFAULT NULL ,grp4 IN a.name%TYPE DEFAULT NULL ,grp5 IN a.name%TYPE DEFAULT NULL ,flag1 IN a.flag%TYPE DEFAULT 'F' ,flag2 IN a.flag%TYPE DEFAULT 'F' ,refercursor_out OUT SYS_REFCURSOR );
我的java程序:
import java.io.IOException; import java.sql.CallableStatement; import java.sql.Connection; import java.sql.DriverManager; import java.sql.ResultSet; import java.sql.SQLException; import oracle.jdbc.driver.OracleTypes; class DAO1 { public static void main(String args[]) throws SQLException, IOException { // Load the driver DriverManager.registerDriver(new oracle.jdbc.driver.OracleDriver()); Connection conn = DriverManager .getConnection("jdbc:oracle:thin:admin/admin@//host1:1521/abcdev"); System.out.println(conn); // Prepare to call the stored procedure get_group_details. CallableStatement cstmt = conn .prepareCall("{call mypackage.get_records (?,?,?,?,?,?,?,?)}"); cstmt.registerOutParameter(8, OracleTypes.CURSOR); // REF CURSOR cstmt.setString(1, ""); cstmt.setString(2, ""); cstmt.setString(3, ""); cstmt.setString(4, ""); cstmt.setString(5, ""); cstmt.setString(6, ""); cstmt.setString(7, ""); // execute get_records //cstmt.execute(); //updated cstmt.executeQuery(); //updated ResultSet rs0 = (ResultSet) cstmt.getObject(8); System.out.println("rs0 is " + rs0.next()); /* * ResultSet rs = ((OracleCallableStatement) cstmt).getCursor(8); * System.out.println("rs is " + rs.next()); * * while (rs.next()) { System.out.println(".."); } */ // Close the statement cstmt.close(); // Close the connection conn.close(); } }
当前输出:
oracle.jdbc.driver.OracleConnection@5afec107 rs0 is false
问题-为什么是错误的?我期望结果集中有100条记录。有记录,并且在执行sql Developer的测试脚本时可见。
begin mypackage.get_records(refercursor_out => :refercursor_out); end; // this returns 100's of records
更新时间:08/08
我没有获取数据的原因不是代码问题,当我将一些值传递给第六个参数时,它正在返回数据。因此关闭线程;将@KlasLindbäck的答案标记为建议正确执行方法的答案。[尽管在这种情况下,execute(),executeQuery()和executeUpdate()返回结果集中的数据]
您没有使用正确的语义。execute具有以外的语义executeQuery。
execute
executeQuery
execute方法返回一个布尔值,以指示第一个结果的形式。您必须调用方法getResultSet或getUpdateCount来检索结果。您必须调用getMoreResults才能移至任何后续结果。
最简单的解决方案(最小的代码更改)是切换到executeQuery:
// execute get_records cstmt.executeQuery();