自动化测试需要连接数据库,进行一些增删改查的操作,那么针对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、再次执行代码,就好了,大功告成!