cx_oracle ORA-01036: недопустимое имя/номер переменной

У меня есть эта группа скриптов Python, где я делаю вызов API, объединяю полученный df вместе, а затем вывожу в таблицу в Oracle db. Этот точный сценарий отлично работает в трех других сценариях, настроенных одинаково, за исключением другого API, но в этом конкретном сценарии возникает эта ошибка. Я читал о привязках, но не понимаю, почему я делаю это неправильно для кортежа. Спасибо заранее за ваше время.

      sf_joined = pd.merge(sf_opp, sf_account,on=["CustID","CustID"])
    # sf_joined.to_csv('sf_joined.csv', index=False)
    
    # sf_types = sf_joined.dtypes
    # print(sf_types)
    
    char_columns = sf_joined.select_dtypes(include=['object']).columns
    
    for col in char_columns:
        if col not in  ['rundate','Amount','Estimated_GC','Probability','MDC','DaysOpen']:
            sf_joined[col] = sf_joined[col].fillna('')
            # sf_joined[col] = sf_joined[col].map(lambda x: x.encode('utf-8'))
            sf_joined[col] = sf_joined[col].map(lambda x: x[:1000])
    
    pw = '****'
    db_con = cx_Oracle.connect('mktg', pw, "prd-bia-db-***.o******.com:1521/BIPRD", encoding = "UTF-8", nencoding = "UTF-8")
    cur = db_con.cursor()
    print(db_con.version)
    
    
    cur.execute('drop table cs_salesforce')
    create_opps = """create table cs_salesforce(
        rundate date,
        sfoppid varchar(500)
    )
    """
    cur.execute(create_opps)
    
    all_opps = []
    
    for x in sf_joined.itertuples():
        all_opps.append(x[1:])
    insert_statement = """insert into cs_salesforce(rundate,sfoppid)values(:1, :2)"""
    
    cur.executemany(insert_statement, all_opps)
    db_con.commit()

Ошибка:

      runfile('C:/python_scripts_prod/cs_salesforce.py', wdir='C:/python_scripts_prod')
18.3.0.0.0
Traceback (most recent call last):

  File "C:\python_scripts_prod\cs_salesforce.py", line 163, in <module>
    cur.executemany(insert_statement, all_opps)

DatabaseError: ORA-01036: illegal variable name/number

0 ответов

Другие вопросы по тегам