首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >为什么在运行python查询之前必须建立一个tnsnames.ora文件?

为什么在运行python查询之前必须建立一个tnsnames.ora文件?
EN

Stack Overflow用户
提问于 2022-08-02 16:10:05
回答 1查看 170关注 0票数 0

使用cx_Oracle (8.3.0)时,只需使用以下代码即可连接到Oracle:

代码语言:javascript
运行
复制
con = cx_Oracle.connect(user = myname, password = mypw, dsn = "myDBprod")

当我用oracledb模块(1.0.2)交换时,我会得到一个错误:

代码语言:javascript
运行
复制
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,但是我不知道为什么所有这些额外的步骤都是必要的。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2022-08-02 16:50:18

我可以解释为什么这是必要的。对于cx_Oracle,需要安装即时客户端(或Oracle )。这些安装具有tnsnames.ora:<install_dir>/network/admin/tnsnames.ora的默认位置。因此,如果将文件放在该位置,则不需要指定其位置。瘦驱动程序不需要安装Oracle客户端(或数据库),因此不存在默认位置。因此,您必须执行以下操作之一:

  • 将环境变量TNS_ADMIN设置为指向发现tnsnames.ora文件的位置,
  • 传递在代码中找到tnsnames.ora文件的位置,如:

代码语言:javascript
运行
复制
con = oracledb.connect(user=myname, password=mypw, dsn="myDBprod",
                       config_dir="/the/directory/of/tnsnames.ora")

如果您已经安装了Oracle (因为您使用的是cx_Oracle),您还可以启用与cx_Oracle相同的厚模式。你可以这样做:

代码语言:javascript
运行
复制
oracledb.init_oracle_client()
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/73210611

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档