2016-07-04 9 views
0

oracle BBDDで関数を返す行の数を数えようとしています。私は他のいくつかの質問(例えば:rs.last() gives Invalid operation for forward only resultset : last)に見てきましたが、それはResultSet.TYPE_SCROLL_INSENSITIVE、ResultSet.CONCUR_READ_ONLYcallablestatementに追加する必要があります。resultset.last()はJavaで例外をスローします

私は結果なし... ResultSet.TYPE_SCROLL_INSENSITIVE、またResultSet.TYPE_SCROLL_SENSITIVEを試してみました。私はまだ同じ無効な操作の例外が発生します。

私が紛失していることはありますか?

HERESに私のコード:

String call = "{ ? = call MyProcedure (?) }"; 
CallableStatement cstmt= conn.prepareCall(call, ResultSet.TYPE_SCROLL_INSENSITIVE, ResultSet.CONCUR_READ_ONLY); 
cstmt.setString(2,"param 1"); 
cstmt.registerOutParameter(1, OracleTypes.CURSOR); 

cstmt.execute(); 
ResultSet rset = (ResultSet)cstmt.getObject(1); 
rset.last(); //Exception comes here 
int rowsnumber = rset.getRow(); 

感謝。

編集:

create or replace FUNCTION MyProcedure 
(IdC IN VARCHAR2 
) 
RETURN sys_refcursor 
IS 
    c_result sys_refcursor; 
BEGIN 
    OPEN c_result FOR SELECT name, properties FROM city WHERE name = IdC; 
    RETURN c_result; 
END; 

、スタックトレースを:移動する

Stack: java.sql.SQLException: Operación no válida para el juego de resultados de sólo reenvío : last 
    at oracle.jdbc.driver.InsensitiveScrollableResultSet.last(InsensitiveScrollableResultSet.java:646) 
    at MyPackage.CoreWS.ExProcedure(CoreWS.java:58) 
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) 
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) 
    at java.lang.reflect.Method.invoke(Method.java:498) 
    at weblogic.wsee.jaxws.WLSInstanceResolver$WLSInvoker.invoke(WLSInstanceResolver.java:120) 
    at weblogic.wsee.jaxws.WLSInstanceResolver$WLSInvoker.invoke(WLSInstanceResolver.java:93) 
    at com.sun.xml.ws.server.InvokerTube$2.invoke(InvokerTube.java:149) 
    at com.sun.xml.ws.server.sei.SEIInvokerTube.processRequest(SEIInvokerTube.java:88) 
    at com.sun.xml.ws.api.pipe.Fiber.__doRun(Fiber.java:1136) 
    at com.sun.xml.ws.api.pipe.Fiber._doRun(Fiber.java:1050) 
    at com.sun.xml.ws.api.pipe.Fiber.doRun(Fiber.java:1019) 
    at com.sun.xml.ws.api.pipe.Fiber.runSync(Fiber.java:877) 
    at com.sun.xml.ws.server.WSEndpointImpl$2.process(WSEndpointImpl.java:419) 
    at com.sun.xml.ws.transport.http.HttpAdapter$HttpToolkit.handle(HttpAdapter.java:868) 
    at com.sun.xml.ws.transport.http.HttpAdapter.handle(HttpAdapter.java:422) 
    at com.sun.xml.ws.transport.http.servlet.ServletAdapter.handle(ServletAdapter.java:169) 
    at weblogic.wsee.jaxws.WLSServletAdapter.handle(WLSServletAdapter.java:229) 
    at weblogic.wsee.jaxws.HttpServletAdapter$AuthorizedInvoke.run(HttpServletAdapter.java:667) 
    at weblogic.security.acl.internal.AuthenticatedSubject.doAs(AuthenticatedSubject.java:368) 
    at weblogic.security.service.SecurityManager.runAs(SecurityManager.java:163) 
    at weblogic.wsee.util.ServerSecurityHelper.authenticatedInvoke(ServerSecurityHelper.java:108) 
    at weblogic.wsee.jaxws.HttpServletAdapter$3.run(HttpServletAdapter.java:286) 
    at weblogic.wsee.jaxws.HttpServletAdapter.post(HttpServletAdapter.java:295) 
    at weblogic.wsee.jaxws.JAXWSServlet.doRequest(JAXWSServlet.java:128) 
    at weblogic.servlet.http.AbstractAsyncServlet.service(AbstractAsyncServlet.java:103) 
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:790) 
    at weblogic.servlet.internal.StubSecurityHelper$ServletServiceAction.run(StubSecurityHelper.java:286) 
    at weblogic.servlet.internal.StubSecurityHelper$ServletServiceAction.run(StubSecurityHelper.java:260) 
    at weblogic.servlet.internal.StubSecurityHelper.invokeServlet(StubSecurityHelper.java:137) 
    at weblogic.servlet.internal.ServletStubImpl.execute(ServletStubImpl.java:350) 
    at weblogic.servlet.internal.ServletStubImpl.execute(ServletStubImpl.java:247) 
    at weblogic.servlet.internal.WebAppServletContext$ServletInvocationAction.wrapRun(WebAppServletContext.java:3679) 
    at weblogic.servlet.internal.WebAppServletContext$ServletInvocationAction.run(WebAppServletContext.java:3649) 
    at weblogic.security.acl.internal.AuthenticatedSubject.doAs(AuthenticatedSubject.java:326) 
    at weblogic.security.service.SecurityManager.runAsForUserCode(SecurityManager.java:197) 
    at weblogic.servlet.provider.WlsSecurityProvider.runAsForUserCode(WlsSecurityProvider.java:203) 
    at weblogic.servlet.provider.WlsSubjectHandle.run(WlsSubjectHandle.java:71) 
    at weblogic.servlet.internal.WebAppServletContext.doSecuredExecute(WebAppServletContext.java:2433) 
    at weblogic.servlet.internal.WebAppServletContext.securedExecute(WebAppServletContext.java:2281) 
    at weblogic.servlet.internal.WebAppServletContext.execute(WebAppServletContext.java:2259) 
    at weblogic.servlet.internal.ServletRequestImpl.runInternal(ServletRequestImpl.java:1686) 
    at weblogic.servlet.internal.ServletRequestImpl.run(ServletRequestImpl.java:1646) 
    at weblogic.servlet.provider.ContainerSupportProviderImpl$WlsRequestExecutor.run(ContainerSupportProviderImpl.java:270) 
    at weblogic.invocation.ComponentInvocationContextManager._runAs(ComponentInvocationContextManager.java:348) 
    at weblogic.invocation.ComponentInvocationContextManager.runAs(ComponentInvocationContextManager.java:333) 
    at weblogic.work.LivePartitionUtility.doRunWorkUnderContext(LivePartitionUtility.java:54) 
    at weblogic.work.PartitionUtility.runWorkUnderContext(PartitionUtility.java:41) 
    at weblogic.work.SelfTuningWorkManagerImpl.runWorkUnderContext(SelfTuningWorkManagerImpl.java:640) 
    at weblogic.work.ExecuteThread.execute(ExecuteThread.java:406) 
    at weblogic.work.ExecuteThread.run(ExecuteThread.java:346) 
+2

スタックトレースを追加 – Jens

+0

これを試してみてください。 [jdbcの結果セットの最後の行に移動](http://stackoverflow.com/questions/10659083/go-to-last-row-from-result-set-in-jdbc-with-sql-server) –

+0

Isそれは本当に無効な操作またはSQLFeatureNotSupportedException – Fildor

答えて

0

能力としてはコメントで言っ

、私は私が呼んでいる最初のOracleの機能を追加そのカーソルは、ResultSetのデフォルトの動作であり、JDBC 1.0 APIのみを実装するドライバでは、カーソル移動が可能です。 。このような結果セットは、ResultSet.TYPE_FORWARD_ONLYタイプを持ち、前方のみの結果セットと呼ばれます。

ドライバがJDBC 2.0コアAPIのカーソル移動メソッドを実装する場合、その結果セットはスクロール可能です。スクロール可能な結果セットのカーソルは、前後に移動することも、特定の行に移動することもできます。以下のメソッドは、カーソルを後方に、最初の行に、最後の行に、特定の行番号に、現在の行から指定された行数に移動します。previous、first、last、absolute、relative、afterLast 、およびbeforeFirst。

APIのバージョンを確認できますか?

参考:Result set

またコメントでマークRotteveelによって示唆されているように、なぜあなたはoutparameterとしてカーソルをしない代わりに、機能にRETURNを使用しての明示的にフェッチし、それが動作しているかどうかを確認しますか?

関連する問題