繁体   English   中英

错误:在 python 中使用 cx_oracle 的语法无效

[英]Error: invalid syntax using cx_oracle in python

下面的代码用于从 csv 文件中的 oracle 数据库中提取数据。 在查询中,为了将小数转换为日期格式,我使用To_Date('12/30/1899', 'MM/DD/YYYY HH24:MI:SS')+DTIMESTAMP) Decoded_Date

并且还指定了提取日期之间数据的日期范围。 请帮助下面给出无效语法的代码有什么问题。

import csv
import cx_Oracle
dsn_tns = cx_Oracle.makedsn('hostname', 'port', sid='sid') # if needed, place an 'r' before any parameter in order to address special characters such as '\'.
conn = cx_Oracle.connect(user=r'username', password='password', dsn=dsn_tns)
cursor = conn.cursor()
csv_file = open("C:/Users/locations.csv", "w")
writer = csv.writer(csv_file, delimiter=',', lineterminator="\n", quoting=csv.QUOTE_NONNUMERIC)
r = cursor.execute("""SELECT * 
                        FROM (SELECT LROWNUM,DTIMESTAMP,LSCENARIO,LYEAR,LPERIOD,
                                     LENTITY,LPARENT,LVALUE,LACCOUNT,LICP,LCUSTOM1,
                                     LCUSTOM2,STRUSERNAME,STRSERVERNAME,
                                     LACTIVITY,DDATAVALUE,BNODATA,
                                     (To_Date('12/30/1899', 'MM/DD/YYYY HH24:MI:SS')+DTIMESTAMP) Decoded_Date
                                FROM TABLE_NAME
                             ) SUB
                       WHERE SUB.Decoded_Date between '23-MAR-2020' and '24-APR-2020';
    """)
for row in cursor:
    writer.writerow(row)

cursor.close()
conn.close()
csv_file.close()

不应出现左括号和右括号。 当然,我不能直接测试 SQL,但理论上这应该适合你!

    r = cursor.execute"""
            SELECT * 
            FROM
                ( SELECT LROWNUM,DTIMESTAMP,LSCENARIO,LYEAR,LPERIOD,
                      LENTITY,LPARENT,LVALUE,LACCOUNT,LICP,LCUSTOM1,
                      LCUSTOM2,STRUSERNAME,STRSERVERNAME,
                      LACTIVITY,DDATAVALUE,BNODATA,
                      To_Date('12/30/1899','MM/DD/YYYY') +
                          DTIMESTAMP as Decoded_Date
                  FROM TABLE_NAME
                ) SUB
            WHERE SUB.Decoded_Date between to_date('23-MAR-2020', 'DD-MON-YYYY')
                  and to_date('24-APR-2020', 'DD-MON-YYYY')
    """

还要注意对最后一行的更改。 除非您知道 NLS_DATE_FORMAT 的值,否则您不能直接将字符串与日期进行比较。 请注意,您也可以直接绑定日期值,如

sql = "select ... where sub.decoded_date between :1 and :2"
cursor.execute(sql, [datetime.date(2020, 3, 23), datetime.date(2020, 4, 24)])

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM