我在 oracle (lro_dummy) 中有一个自定义类型。我也有程序。我看起来像这样:
procedure dummyLro
(
i_dummy in lro_dummy,
o_dummy out lro_dummy
)is
begin
o_dummy := lro_dummy('asdf');
end dummyLro;
现在我想用 cx_Oracle 从 python 调用这个过程。这看起来像这样:
def test(db_con):
cur = db_con.cursor()
try:
procedure_params = {}
procedure_params["i_dummy"] = cur.var(cx_Oracle.OBJECT, typename="lro_dummy")
procedure_params["o_dummy"] = cur.var(cx_Oracle.OBJECT, typename="lro_dummy")
cur.callproc("test.dummyLro", [], procedure_params)
之后o_dummy
有一个值,因为
str(procedures_params["o_dummy"])
返回
'<cx_Oracle.OBJECT with value <cx_Oracle.Object ???.LRO_DUMMY at 0x10492c9c0>>'
但我无法访问我的属性。属性列在
procedure_params["o_dummy"].type.attributes
但我找不到价值
procedure_params["o_dummy"]
我做错了什么?
我正在使用Python 3.6
, cx_Oracle 5.3
, InstantClient 11.2
,Oracle-Server 11