自动化测试之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、再次执行代码,就好了,大功告成!
在这里插入图片描述

  • 11
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

如梦@_@

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值