Frage

Ich versuche, diese wieder auf eine Oracle-Datenbank 10 zu tun:

cursor = connection.cursor()
lOutput = cursor.var(cx_Oracle.STRING)
cursor.execute("""
            BEGIN
                %(out)s := 'N';
            END;""",
            {'out' : lOutput})
print lOutput.value

, aber ich bin immer

DatabaseError: ORA-01036: illegal variable name/number

Ist es möglich, PL / SQL-Blöcke in cx_Oracle auf diese Weise zu definieren?

War es hilfreich?

Lösung

Ja, können Sie die anonyme PL / SQL-Blöcke tun. Ihre Bindevariablen für den Ausgabeparameter ist nicht im richtigen Format. Es sollte :out statt %(out)s

sein
cursor = connection.cursor()
lOutput = cursor.var(cx_Oracle.STRING)
cursor.execute("""
            BEGIN
                :out := 'N';
            END;""",
            {'out' : lOutput})
print lOutput

, die die Ausgabe erzeugt:

<cx_Oracle.STRING with value 'N'>
Lizenziert unter: CC-BY-SA mit Zuschreibung
Nicht verbunden mit StackOverflow
scroll top