自学内容网 自学内容网

自动化测试之python操作Oracle遇到的问题:Oracle-Error-Message: DPI-1047

自动化测试需要连接数据库,进行一些增删改查的操作,那么针对python语言,如何才能够通过程序完成连接数据库并且进行操作呢?可以通过cx_oracle这个模块来实现。

一、问题描述:

下面是我在实践的过程中遇到的问题,先看下我的代码:

import cx_Oracle
try:
    connection = cx_Oracle.connect(user="****", password="****", dsn="hostip/****")
    cursor = connection.cursor()
    cursor.execute("SELECT * FROM databaseName lir WHERE lir.GROUP_ID = 'T999'")
    for row in cursor:
        print(row)
except cx_Oracle.DatabaseError as e:
    error, = e.args
    print(f"Oracle-Error-Code: {error.code}")
    print(f"Oracle-Error-Message: {error.message}")
finally:
    if 'cursor' in locals():
        cursor.close()
    if 'connection' in locals():
        connection.close()

执行代码,报如下错误:
Oracle-Error-Code: 0
Oracle-Error-Message: DPI-1047: Cannot locate a 64-bit Oracle Client library: “The specified module could not be found”. See https://cx-oracle.readthedocs.io/en/latest/user_guide/installation.html for help
在这里插入图片描述
可以直观的看到:是因为没有安装Oracle client,Oracle是cs架构的。
那么接下来就来解决这个问题:

二、解决问题

1、先安装Oracle client,在自己的本地安装,也就是你的代码执行的机器上安装,我的是本地的windows11,64-bit。那么先到官网上下载zip包:
https://www.oracle.com/database/technologies/instant-client/winx64-64-downloads.html
我这里下载的是19版本的,basic package:
在这里插入图片描述
下载完成后,解压到:C:\oracle\instantclient_19_11 这个路径下:
在这里插入图片描述
2、配置环境变量:
这里的地址不能只写到解压的这个目录:C:\oracle\instantclient_19_11
正确的写法应该是:C:\oracle\instantclient_19_11\instantclient-basic-windows.x64-19.23.0.0.0dbru\instantclient_19_23
在这里插入图片描述
在这里插入图片描述
应该填写到解压后进入的这个目录。
3、将上面图中解压的文件路径下的所有.dll文件复制到pycharm的安装目录,pycharm的安装目录在:C:\Program Files\JetBrains\PyCharm Community Edition 2021.2.3
在这里插入图片描述
4、重启pycharm,并修改代码:
增加如下一行:

import cx_Oracle
cx_Oracle.init_oracle_client(lib_dir=r"C:\oracle\instantclient_19_11\instantclient-basic-windows.x64-19.23.0.0.0dbru\instantclient_19_23")

注意这里的lib_dir是上面的path中添加的,千万不能错,错的话就还是找不到Oracle libraries。

5、再次执行代码,就好了,大功告成!
在这里插入图片描述


原文地址:https://blog.csdn.net/weixin_43726471/article/details/140630370

免责声明:本站文章内容转载自网络资源,如本站内容侵犯了原著者的合法权益,可联系本站删除。更多内容请关注自学内容网(zxcms.com)!