我将表类型发送到存储过程。以下是声明的类型。
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。
之类的东西我如何才能做到这一点。
答案 0 :(得分:1)
您可以尝试setattr(对象,名称,值)。
setattr(new_obj, 'SSN', 1111)
setattr(new_obj, 'FNAME', 'John')