使用cx_Oracle (8.3.0)时,只需使用以下代码即可连接到Oracle:
con = cx_Oracle.connect(user = myname, password = mypw, dsn = "myDBprod")
当我用oracledb模块(1.0.2)交换时,我会得到一个错误:
con = oracledb.connect(user = myname, password = mypw, dsn = "myDBprod")
DatabaseError: DPY-4026: cannot connect to database. File tnsnames.ora not found in C:\Oracle\InstantAdmin
在研究这个问题时,我发现了这个帖子:With python-oracledb what does 'DPY-4027: no configuration directory to search for tnsnames.ora' mean,但是我不知道为什么所有这些额外的步骤都是必要的。
发布于 2022-08-02 16:50:18
我可以解释为什么这是必要的。对于cx_Oracle,需要安装即时客户端(或Oracle )。这些安装具有tnsnames.ora:<install_dir>/network/admin/tnsnames.ora
的默认位置。因此,如果将文件放在该位置,则不需要指定其位置。瘦驱动程序不需要安装Oracle客户端(或数据库),因此不存在默认位置。因此,您必须执行以下操作之一:
TNS_ADMIN
设置为指向发现tnsnames.ora文件的位置,con = oracledb.connect(user=myname, password=mypw, dsn="myDBprod",
config_dir="/the/directory/of/tnsnames.ora")
如果您已经安装了Oracle (因为您使用的是cx_Oracle),您还可以启用与cx_Oracle相同的厚模式。你可以这样做:
oracledb.init_oracle_client()
https://stackoverflow.com/questions/73210611
复制相似问题