К сожалению, нет, по крайней мере, не напрямую! Вы можете использовать PL / SQL, чтобы разбить запись на кусочки, например, если у вас есть запись PKG_DEMO.UDT_DEMORECORD
, вы можете сделать что-то вроде следующего:
import cx_Oracle
import datetime
conn = cx_Oracle.connect("pythondemo/welcome")
cursor = conn.cursor()
numVar = cursor.var(int)
strVar = cursor.var(str)
dateVar = cursor.var(datetime.datetime)
boolVar = cursor.var(bool)
numVar.setvalue(0, 6)
strVar.setvalue(0, "Test String")
dateVar.setvalue(0, datetime.datetime(2016, 5, 28))
boolVar.setvalue(0, False)
# show the original values
print("NUMBERVALUE ->", numVar.getvalue())
print("STRINGVALUE ->", strVar.getvalue())
print("DATEVALUE ->", dateVar.getvalue())
print("BOOLEANVALUE ->", boolVar.getvalue())
print()
cursor.execute("""
declare
t_Record pkg_Demo.udt_DemoRecord;
begin
t_Record.NumberValue := :numVar;
t_Record.StringValue := :strVar;
t_Record.DateValue := :dateVar;
t_Record.BooleanValue := :boolVar;
pkg_Demo.DemoRecordsInOut(t_Record);
:numVar := t_Record.NumberValue;
:strVar := t_Record.StringValue;
:dateVar := t_Record.DateValue;
:boolVar := t_Record.BooleanValue;
end;""",
numVar = numVar,
strVar = strVar,
dateVar = dateVar,
boolVar = boolVar)
# show the modified values
print("NUMBERVALUE ->", numVar.getvalue())
print("STRINGVALUE ->", strVar.getvalue())
print("DATEVALUE ->", dateVar.getvalue())
print("BOOLEANVALUE ->", boolVar.getvalue())
print()
Как вы можете, это намного сложнее, чем оригинальная демоверсия - но это работает!