Call stored procedure IBM

Hi, i’m trying to call a procedure in as400 / iseries like this

call = system.db.createSProcCall('ESTLIB/STPTEST','as400_Conn')
call.registerInParam("PrmCod", system.db.CHAR, "a")
call.registerOutParam("PrmRis", system.db.CHAR)
  
ds = system.db.execSProcCall(call)
results = call.getResultSet()

the procedure exists, and in other ways I can call it, but with ignition it gives me this error:

Traceback (most recent call last):
  File "<event:mouseClicked>", line 5, in <module>
	at com.inductiveautomation.ignition.common.script.builtin.AbstractDBUtilities.error(AbstractDBUtilities.java:362)

	at com.inductiveautomation.ignition.common.script.builtin.AbstractDBUtilities.execSProcCall(AbstractDBUtilities.java:496)

	at sun.reflect.GeneratedMethodAccessor197.invoke(Unknown Source)

	at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)

	at java.lang.reflect.Method.invoke(Unknown Source)


java.lang.Exception: java.lang.Exception: Error executing system.db.execSProcCall()

	at org.python.core.Py.JavaError(Py.java:495)
	at com.inductiveautomation.ignition.common.script.builtin.AbstractDBUtilities.error(AbstractDBUtilities.java:362)
	at com.inductiveautomation.ignition.common.script.builtin.AbstractDBUtilities.execSProcCall(AbstractDBUtilities.java:496)
	at sun.reflect.GeneratedMethodAccessor197.invoke(Unknown Source)
	at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
	at java.lang.reflect.Method.invoke(Unknown Source)
	at org.python.core.PyReflectedFunction.__call__(PyReflectedFunction.java:186)
	at com.inductiveautomation.ignition.common.script.ScriptManager$ReflectedInstanceFunction.__call__(ScriptManager.java:431)
	at org.python.core.PyObject.__call__(PyObject.java:387)
	at org.python.core.PyObject.__call__(PyObject.java:391)
	at org.python.pycode._pyx65.f$0(<event:mouseClicked>:8)
	at org.python.pycode._pyx65.call_function(<event:mouseClicked>)
	at org.python.core.PyTableCode.call(PyTableCode.java:165)
	at org.python.core.PyCode.call(PyCode.java:18)
	at org.python.core.Py.runCode(Py.java:1275)
	at com.inductiveautomation.ignition.common.script.ScriptManager.runCode(ScriptManager.java:636)
	at com.inductiveautomation.factorypmi.application.binding.action.ActionAdapter.runActions(ActionAdapter.java:193)
	at com.inductiveautomation.factorypmi.application.binding.action.ActionAdapter.invoke(ActionAdapter.java:284)
	at com.inductiveautomation.factorypmi.application.binding.action.RelayInvocationHandler.invoke(RelayInvocationHandler.java:57)
	at com.sun.proxy.$Proxy33.mouseClicked(Unknown Source)
	at java.awt.AWTEventMulticaster.mouseClicked(Unknown Source)
	at java.awt.Component.processMouseEvent(Unknown Source)
	at javax.swing.JComponent.processMouseEvent(Unknown Source)
	at java.awt.Component.processEvent(Unknown Source)
	at java.awt.Container.processEvent(Unknown Source)
	at java.awt.Component.dispatchEventImpl(Unknown Source)
	at java.awt.Container.dispatchEventImpl(Unknown Source)
	at java.awt.Component.dispatchEvent(Unknown Source)
	at java.awt.LightweightDispatcher.retargetMouseEvent(Unknown Source)
	at java.awt.LightweightDispatcher.processMouseEvent(Unknown Source)
	at java.awt.LightweightDispatcher.dispatchEvent(Unknown Source)
	at java.awt.Container.dispatchEventImpl(Unknown Source)
	at java.awt.Window.dispatchEventImpl(Unknown Source)
	at java.awt.Component.dispatchEvent(Unknown Source)
	at java.awt.EventQueue.dispatchEventImpl(Unknown Source)
	at java.awt.EventQueue.access$500(Unknown Source)
	at java.awt.EventQueue$3.run(Unknown Source)
	at java.awt.EventQueue$3.run(Unknown Source)
	at java.security.AccessController.doPrivileged(Native Method)
	at java.security.ProtectionDomain$JavaSecurityAccessImpl.doIntersectionPrivilege(Unknown Source)
	at java.security.ProtectionDomain$JavaSecurityAccessImpl.doIntersectionPrivilege(Unknown Source)
	at java.awt.EventQueue$4.run(Unknown Source)
	at java.awt.EventQueue$4.run(Unknown Source)
	at java.security.AccessController.doPrivileged(Native Method)
	at java.security.ProtectionDomain$JavaSecurityAccessImpl.doIntersectionPrivilege(Unknown Source)
	at java.awt.EventQueue.dispatchEvent(Unknown Source)
	at java.awt.EventDispatchThread.pumpOneEventForFilters(Unknown Source)
	at java.awt.EventDispatchThread.pumpEventsForFilter(Unknown Source)
	at java.awt.EventDispatchThread.pumpEventsForHierarchy(Unknown Source)
	at java.awt.EventDispatchThread.pumpEvents(Unknown Source)
	at java.awt.EventDispatchThread.pumpEvents(Unknown Source)
	at java.awt.EventDispatchThread.run(Unknown Source)
Caused by: java.lang.Exception: Error executing system.db.execSProcCall()
	... 51 more
Caused by: com.inductiveautomation.ignition.client.gateway_interface.GatewayException: [SQL5016] Nome oggetto qualificato STPTEST non valido. Causa  . . . : Si è verificata una delle seguenti condizioni: -- la sintassi utilizzata per il nome oggetto qualificato non è valida per l'opzione di denominazione specificata. Con la denominazione di sistema, la forma qualificata di un nome oggetto è nome-schema/nome-oggetto. Con la denominazione SQL, la forma qualificata di un nome oggetto è authorization-name.object-name. -- la sintassi utilizzata per il nome oggetto qualificato non è consentita. I tipi definiti dall'utente non possono essere qualificati con lo schema nella convenzione di denominazione del sistema, nei parametri e variabili SQL di una procedura SQL o funzione. Correzione  . . :   Eseguire una di queste operazioni e ripetere la richiesta: -- Se si desidera utilizzare la convenzione di denominazione SQL, verificare che l'opzione di denominazione SQL si trovi nel comando SQL appropriato e qualificare i nomi dell'oggetto nella forma authorization-id.object-name. -- Se si desidera utilizzare la convenzione di denominazione del sistema, specificare l'opzione denominazione sistema nel comando SQL appropriato e qualificare i nomi oggetto nel formato nome-schema/nome-oggetto. -- Con la convenzione di denominazione del sistema, verificare che i tipi definiti dall'utente specificati per i parametri e le variabili in una routine SQL vengano rilevati nel percorso corrente.
	at com.inductiveautomation.ignition.client.gateway_interface.GatewayInterface.newGatewayException(GatewayInterface.java:353)
	at com.inductiveautomation.ignition.client.gateway_interface.GatewayInterface.sendMessage(GatewayInterface.java:327)
	at com.inductiveautomation.ignition.client.gateway_interface.GatewayInterface.sendMessage(GatewayInterface.java:280)
	at com.inductiveautomation.ignition.client.gateway_interface.GatewayInterface.invoke(GatewayInterface.java:912)
	at com.inductiveautomation.ignition.client.script.ClientDBUtilities._call(ClientDBUtilities.java:278)
	at com.inductiveautomation.ignition.common.script.builtin.AbstractDBUtilities.execSProcCall(AbstractDBUtilities.java:494)
	... 49 more
Caused by: com.ibm.as400.access.AS400JDBCSQLSyntaxErrorException: [SQL5016] Nome oggetto qualificato STPTEST non valido. Causa  . . . : Si è verificata una delle seguenti condizioni: -- la sintassi utilizzata per il nome oggetto qualificato non è valida per l'opzione di denominazione specificata. Con la denominazione di sistema, la forma qualificata di un nome oggetto è nome-schema/nome-oggetto. Con la denominazione SQL, la forma qualificata di un nome oggetto è authorization-name.object-name. -- la sintassi utilizzata per il nome oggetto qualificato non è consentita. I tipi definiti dall'utente non possono essere qualificati con lo schema nella convenzione di denominazione del sistema, nei parametri e variabili SQL di una procedura SQL o funzione. Correzione  . . :   Eseguire una di queste operazioni e ripetere la richiesta: -- Se si desidera utilizzare la convenzione di denominazione SQL, verificare che l'opzione di denominazione SQL si trovi nel comando SQL appropriato e qualificare i nomi dell'oggetto nella forma authorization-id.object-name. -- Se si desidera utilizzare la convenzione di denominazione del sistema, specificare l'opzione denominazione sistema nel comando SQL appropriato e qualificare i nomi oggetto nel formato nome-schema/nome-oggetto. -- Con la convenzione di denominazione del sistema, verificare che i tipi definiti dall'utente specificati per i parametri e le variabili in una routine SQL vengano rilevati nel percorso corrente.
	at com.ibm.as400.access.JDError.createSQLExceptionSubClass(JDError.java:948)
	at com.ibm.as400.access.JDError.throwSQLException(JDError.java:745)
	at com.ibm.as400.access.AS400JDBCStatement.commonPrepare(AS400JDBCStatement.java:1790)
	at com.ibm.as400.access.AS400JDBCPreparedStatementImpl.<init>(AS400JDBCPreparedStatementImpl.java:357)
	at com.ibm.as400.access.AS400JDBCCallableStatement.<init>(AS400JDBCCallableStatement.java:126)
	at com.ibm.as400.access.AS400JDBCConnectionImpl.prepareCall(AS400JDBCConnectionImpl.java:2026)
	at com.ibm.as400.access.AS400JDBCConnectionImpl.prepareCall(AS400JDBCConnectionImpl.java:1912)
	at org.apache.commons.dbcp.DelegatingConnection.prepareCall(DelegatingConnection.java:308)
	at org.apache.commons.dbcp.PoolingDataSource$PoolGuardConnectionWrapper.prepareCall(PoolingDataSource.java:303)
	at com.inductiveautomation.ignition.gateway.datasource.SRConnectionWrapper.prepareCall(SRConnectionWrapper.java:432)
	at com.inductiveautomation.ignition.gateway.script.GatewayDBUtilities._callSProc(GatewayDBUtilities.java:224)
	at com.inductiveautomation.ignition.gateway.servlets.gateway.functions.CallSProc.call(CallSProc.java:47)
	at sun.reflect.GeneratedMethodAccessor25.invoke(null)
	at sun.reflect.DelegatingMethodAccessorImpl.invoke(null)
	at java.lang.reflect.Method.invoke(null)
	at com.inductiveautomation.ignition.gateway.servlets.gateway.AbstractGatewayFunction.invoke(AbstractGatewayFunction.java:211)
	at com.inductiveautomation.ignition.gateway.servlets.Gateway.doPost(Gateway.java:433)
	at javax.servlet.http.HttpServlet.service(HttpServlet.java:707)
	at javax.servlet.http.HttpServlet.service(HttpServlet.java:790)
	at com.inductiveautomation.ignition.gateway.bootstrap.MapServlet.service(MapServlet.java:85)
	at org.eclipse.jetty.servlet.ServletHolder$NotAsyncServlet.service(ServletHolder.java:1391)
	at org.eclipse.jetty.servlet.ServletHolder.handle(ServletHolder.java:760)
	at org.eclipse.jetty.servlet.ServletHandler.doHandle(ServletHandler.java:547)
	at org.eclipse.jetty.server.handler.ScopedHandler.handle(ScopedHandler.java:143)
	at org.eclipse.jetty.security.SecurityHandler.handle(SecurityHandler.java:590)
	at org.eclipse.jetty.server.handler.HandlerWrapper.handle(HandlerWrapper.java:127)
	at org.eclipse.jetty.server.handler.ScopedHandler.nextHandle(ScopedHandler.java:235)
	at org.eclipse.jetty.server.session.SessionHandler.doHandle(SessionHandler.java:1607)
	at org.eclipse.jetty.server.handler.ScopedHandler.nextHandle(ScopedHandler.java:233)
	at org.eclipse.jetty.server.handler.ContextHandler.doHandle(ContextHandler.java:1297)
	at org.eclipse.jetty.server.handler.ScopedHandler.nextScope(ScopedHandler.java:188)
	at org.eclipse.jetty.servlet.ServletHandler.doScope(ServletHandler.java:485)
	at org.eclipse.jetty.server.session.SessionHandler.doScope(SessionHandler.java:1577)
	at org.eclipse.jetty.server.handler.ScopedHandler.nextScope(ScopedHandler.java:186)
	at org.eclipse.jetty.server.handler.ContextHandler.doScope(ContextHandler.java:1212)
	at org.eclipse.jetty.server.handler.ScopedHandler.handle(ScopedHandler.java:141)
	at org.eclipse.jetty.server.handler.HandlerList.handle(HandlerList.java:59)
	at org.eclipse.jetty.server.handler.HandlerWrapper.handle(HandlerWrapper.java:127)
	at org.eclipse.jetty.server.Server.handle(Server.java:500)
	at org.eclipse.jetty.server.HttpChannel.lambda$handle$1(HttpChannel.java:383)
	at org.eclipse.jetty.server.HttpChannel.dispatch(HttpChannel.java:547)
	at org.eclipse.jetty.server.HttpChannel.handle(HttpChannel.java:375)
	at org.eclipse.jetty.server.HttpConnection.onFillable(HttpConnection.java:270)
	at org.eclipse.jetty.io.AbstractConnection$ReadCallback.succeeded(AbstractConnection.java:311)
	at org.eclipse.jetty.io.FillInterest.fillable(FillInterest.java:103)
	at org.eclipse.jetty.io.ChannelEndPoint$2.run(ChannelEndPoint.java:117)
	at org.eclipse.jetty.util.thread.strategy.EatWhatYouKill.runTask(EatWhatYouKill.java:336)
	at org.eclipse.jetty.util.thread.strategy.EatWhatYouKill.doProduce(EatWhatYouKill.java:313)
	at org.eclipse.jetty.util.thread.strategy.EatWhatYouKill.tryProduce(EatWhatYouKill.java:171)
	at org.eclipse.jetty.util.thread.strategy.EatWhatYouKill.run(EatWhatYouKill.java:129)
	at org.eclipse.jetty.util.thread.ReservedThreadExecutor$ReservedThread.run(ReservedThreadExecutor.java:388)
	at org.eclipse.jetty.util.thread.QueuedThreadPool.runJob(QueuedThreadPool.java:806)
	at org.eclipse.jetty.util.thread.QueuedThreadPool$Runner.run(QueuedThreadPool.java:938)
	at java.lang.Thread.run(null)

Ignition v7.9.17 (b2021010514)
Java: Oracle Corporation 1.8.0_281

i use JDBC configured with administrator user
what am I doing wrong?

The IBM JDBC driver is returning this error that says the name is invalid.
Not knowing really anything about IBM - are you sure your Ignition connection is to the right schema/database/etc? Are you connecting as a user with privileges for this procedure? Does the DB have a concept of privileges per connecting IP - maybe it's rejecting the Ignition user because it's coming from a non-accepted IP address?

1 Like

Hi, thank you!
yes the problem was the connection syntax
which is not “Schema/Object” but “Schema.Object”

1 Like