从Python发送表类型到存储过程

时间:2018-04-02 16:56:38

标签: python plsql cx-oracle

我将表类型发送到存储过程。以下是声明的类型。

CREATE TYPE two_attr_ot AS OBJECT (
ssn      NUMBER,
fname    VARCHAR2(100)
);

CREATE TYPE two_attr_tt IS TABLE OF two_attr_ot;

程序

PROCEDURE set_emp_details(
    IN_save_data IN two_attr_tt
)

我使用cx_Oracle从python调用此过程。 conn是连接对象。

tab = conn.gettype('two_attr_tt')
obj = conn.gettype('TWO_ATTR_OT')
new_obj = obj.newobject()
new_obj.SSN = 1111
new_obj.FNAME = 'John'
tab.append(new_obj)
conn.cursor().callproc('procname', [tab])

执行得非常好。但我想使用动态键动态地将属性设置为new_obj。像new_obj [key] = val。

之类的东西

我如何才能做到这一点。

1 个答案:

答案 0 :(得分:1)

您可以尝试setattr(对象,名称,值)。

setattr(new_obj, 'SSN', 1111)
setattr(new_obj, 'FNAME', 'John')