gpt4 book ai didi

python - cx_Oracle : Using PL/SQL RECORD types as arguments to stored procedures

转载 作者:太空宇宙 更新时间:2023-11-04 05:02:41 25 4
gpt4 key购买 nike

我正在尝试从 cx_Oracle 调用 AP_VENDOR_PUB_PKG.CREATE_VENDOR(这是一个 Oracle R12 存储过程)它需要一个预定义 PL/SQL RECORD 类型的参数。 (AP_VENDOR_PUB_PKG.R_VENDOR_REC_TYPE)

这是我的 python 代码:

connection = cx_Oracle.connect(...)
cursor = connection.cursor()
obj = cursor.var(cx_Oracle.Object,
typename='AP_VENDOR_PUB_PKG.R_VENDOR_REC_TYPE')
result = cursor.callproc('AP_VENDOR_PUB_PKG.CREATE_VENDOR',
parameters=["1.0", "T", "T",
"fnd_api.g_valid_level_full", obj])

这会导致以下异常:

cx_Oracle.InterfaceError: 对象类型未与绑定(bind)变量关联

我做错了什么?如何调用需要记录类型的存储过程?

最佳答案

我已经能够通过使用来解决这个问题

type_obj = connection.gettype('AP_VENDOR_PUB_PKG_R_VENDOR_RE')
obj = type_obj.newobject()

注意名称限制在29个字符以内,句点(.)已被下划线(_)代替

关于python - cx_Oracle : Using PL/SQL RECORD types as arguments to stored procedures,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45360966/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com