python - 使用 zxJDBC 调用过程中的参数数量或类型错误
问题描述
我从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:调用“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])
解决方案
当您有一个 OUT 或 IN OUT 参数时,您必须传递一个变量,而不是该参数的文字。该过程如何将值传回?
推荐阅读
- macos - al和dl有区别吗?
- oracle - 如何立即打印sqlplus输出
- flutter - 颤振图像选择器不提供图像路径
- delphi - DELPHI“调用的对象已与其客户端断开连接”
- ios - xcode11 - 在 ios 13 中请求位置服务的授权
- vue.js - vue apollo 4 不返回 graphql 查询结果
- linux - 有没有办法将端口 X 上的现有 Web 服务“托管”为端口 80 上另一个 Web 服务的网络路径?
- .net - Microsoft.NET.Sdk.Publish 不会将文件复制到发布目录
- r - 提取考虑不同模式的模式
- robotframework - Robot Framework - 连接到新的 shell 并执行命令