我正在尝试从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方法返回一个布尔值,以指示第一个结果的形式。您必须调用方法getResultSet或getUpdateCount来检索结果。您必须调用getMoreResults才能移至任何后续结果。
最简单的解决方案(最小的代码更改)是切换到executeQuery
:
// execute get_records
cstmt.executeQuery();
问题内容: 我正在调用一个Sybase存储过程,该存储过程通过JDBC返回多个结果集。我需要获取一个具有名为“ Result”的列的特定结果集,这是我的代码: 这里发生的是返回很多空结果集,直到达到目标结果集为止。我不能用作循环条件,因为它对空结果集返回false。 我放置了一个固定数字以结束循环,条件是没有返回所需的结果集,以防止其进入无限循环。它工作正常,但我认为这是不对的。 我认为从Syba
问题内容: 我有一个MYSQL存储过程SP1(),它返回一个结果集。 我想在SP2()内部调用SP1()并遍历SP1()的结果集以执行一些其他工作。 我不想从SP1()中包含我的逻辑,因为这会使SP2()过于复杂。 有什么建议么? 谢谢。 问题答案: 您想做的事情听起来并不是特别好,也许您应该考虑重新设计这两个过程。但是,您可以执行以下操作来快速解决此问题: 使您的sp2 sproc将其中间结果写
我想将结果添加到resultset,并使用table显示结果,这是我的java代码 错误显示"未找到列'Janunary'。" 很抱歉我没有获得足够的声誉,所以我将存储过程的结果写如下。 查询代码:
问题内容: 由于某些奇怪的原因,我无法从Python测试应用程序中的callproc调用中获得结果。MqSQL 5.2.47中的存储过程如下所示: 现在,在Python 3.3中使用PyCharm时,在调用此存储过程时似乎什么也找不到。这段代码为我提供了预期的结果: 但是这段代码带有cursor.fetchall()或cursor.fetchone()… …返回“ mysql.connector.
我无法在spring data jpa(版本1.11.16)和oracle服务器中使用带有游标的存储过程。 存储库: 实体上的注释: 这是我调用时的java响应: ↓ 2018-12-11 13:07:26.047调试24164---[nio-9090-exec-2]org.hibernate。SQL:{调用POC_PKG_GEO.PRO_RETURN_REGION(?,)}Hibernate:{
我通过Hibernate调用了一个带有OUT参数的存储过程,得到了以下错误: 我的存储过程: Hibernate映射: 我按如下方式调用了存储过程: 有人能解释一下这段代码有什么问题吗?