Неверное количество или типы аргументов в вызове процедуры с использованием zxJDBC - PullRequest
0 голосов
/ 27 декабря 2018

Я взял официальный пример из http://www.jython.org/archive/21/docs/zxjdbc.html:

Oracle
>>> c = db.cursor() # open the database as in the examples above
>>> c.execute("create or replace function funcout (y out varchar2) return varchar2 is begin y := 'tested'; return 'returned'; end;")
>>> params = [None]
>>> c.callproc("funcout", params)
>>> print params

Когда я запускаю этот код, я получаю исключение:

PLS-00306: неверный номер или типы аргументов в вызовеto 'FUNCOUT' ORA-06550: строка 1, столбец 7: PL / SQL: оператор игнорируется

Как это исправить?

Дополнение !!!Также не работает этот код:

  outParam = ""
            self.cursor.execute("create or replace function funcout (y out varchar2) return varchar2 is begin y := 'tested'; return 'returned'; end;")
            self.cursor.callproc("funcout", [outParam])

Ответы [ 2 ]

0 голосов
/ 06 января 2019

Вы можете взглянуть на PLSQLSample.java

0 голосов
/ 27 декабря 2018

Если у вас есть параметр OUT или IN OUT, вы должны передать переменную, а не литерал для этого параметра.Как еще процедура может передать значение обратно?

...