Get ResultSet from Stored Procedure in Oracle from Java

╄→尐↘猪︶ㄣ 提交于 2019-12-23 04:45:38

问题


I've been looking through many posts in the forum related to my problem but I nothing helped me, so I'm posting my problem. I have a SP in Oracle (11g) that is suppossed to return a Result Set. The SP looks like follows:

CREATE OR REPLACE
PROCEDURE testProc
(
  tableName IN VARCHAR2,
  INFORMATION OUT SYS_REFCURSOR
) AS 
  sqlQuery varchar2(1000);
BEGIN
  sqlQuery := 'SELECT ID||''|''||Name||''|''||Surname FROM '||tableName;
  OPEN INFORMATION FOR sqlQuery;
END GETVALIDATIONPECLOG;

And the way I'm calling it from java is

...
CallableStatement cs = null 
cs = connection.prepareCall("{call getvalidationpeclog(?,?)}");
cs.setString(1, table);
cs.registerOutParameter(2, OracleTypes.CURSOR);
System.out.println("AS: " + cs.execute()); //Returns false
rs = (ResultSet) cs.getObject(2);
while (rs.next()) {
   bw.write(rs.getString(1));
   bw.newLine();
}
...

but guess what? It doesn't work at all... What am I missing? Thanks !


回答1:


OK. Sorry my fault. I wasn't closing the BufferedWriter... That code works really fine.



来源:https://stackoverflow.com/questions/7973284/get-resultset-from-stored-procedure-in-oracle-from-java

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!