sql >> Database >  >> RDS >> Oracle

Expressie is van het verkeerde type bij het aanroepen van de functie met cx_Oracle

Naar aanleiding van de suggestie van kfinity over het gebruik van een anonieme blokomslag en een vrij vergelijkbare vraag , gaat de volgende code werken:

outVal = cursor.var(int)
phase = cursor.var(cx_Oracle.STRING)
status = cursor.var(cx_Oracle.STRING)
dev_phase = cursor.var(cx_Oracle.STRING)
dev_status = cursor.var(cx_Oracle.STRING)
message = cursor.var(cx_Oracle.STRING)
sql="""
  begin
    :outVal := sys.diutil.bool_to_int(
        fnd_concurrent.wait_for_request(
            :id,
            :interval, 
            :max_wait,
            :phase,
            :status,
            :dev_phase,
            :dev_status,
            :message
        )
    );
  end;
  """
cursor.execute( 
    sql,
    outVal=outVal,
    id='141116467',
    interval='1',
    max_wait='1',
    phase=phase,
    status=status,
    dev_phase=dev_phase,
    dev_status=dev_status,
    message=message
)
print(outVal.getvalue())


  1. SQL #1064 tijdens het gebruik van phpMyAdmin

  2. Soms KUNT u een kolom op zijn plaats vergroten

  3. FOUT #1054 - Onbekende kolom 'program_id' in 'NIEUW

  4. Formulier niet opslaan in database