Python连接Oracle数据库完美教程

简介: Python连接Oracle数据库完美教程

最近小豆君在做python连接Oracle数据库时发现有很多坑,网上搜到的也是不够详细,故整理一下供大家参考,避免入坑

1 场景

你已经在服务器上创建了Oracle数据库

现在要用python去连接Oracle


2 连接Oracle基本知识

01ebd755782e4c909dad0843d3544acf.jpeg

我们使用python库cx_Oracle来连接Oracle

Oracle分服务端和客户端、服务端又分监听程序和数据库实例

所以,当我们在本地开发时,需要安装cx_Oracle、OracleClient


3 部件下载

我们确认的顺序是,一定要注意,如果你的python和OracleClient要都是32位的,64位的同理。

也就是说,只能有以下两种组合情况:

python_x86 => cx_Oracle(32和64都可以) => OracleClient_x86

python_x64 => cx_Oracle(32和64都可以) => OracleClient_x64

python我就不说了,直接到官网下

2.1 cx_Oracle

python3.6或更高版本,直接使用pip下载最新的即可

方法1: pip安装:python -m pip install cx_Oracle --upgrade

如果是python2,你需要下7.3版本的

方法2:下载其它版本 https://pypi.org/project/cx-Oracle/#history

要选择对应python版本的包下载

pip install xxx.whl

01ebd755782e4c909dad0843d3544acf.jpeg


2.2 Oracle Instant Client

Free tools and libraries for connecting to Oracle Database

01ebd755782e4c909dad0843d3544acf.jpeg

虽然oracle官网有如下介绍:

版本21客户端库可以连接到Oracle数据库12.1或更高版本。版本19、18和12.2的客户端库可以连接到Oracle数据库11.2或更高版本。12.1版本的客户端库可以连接到Oracle数据库10.2或更高版本。版本11.2客户端库可以连接到Oracle数据库9.2或更高版本。

但我还是推荐大家版本最好一一对应,如你要连接oracle11,则下载

01ebd755782e4c909dad0843d3544acf.jpeg

下载的文件解压,复制oci,oraocci11,oraociei11的3个DLL粘贴到你的Python目录的Lib/site-packages文件夹下面。(粘贴原因:不需要配置环境变量) ,否则你需要配置ORACLE_HOME环境变量


4 测试代码

def test():
    import cx_Oracle
    # 去掉以下注释则不需要拷贝动态库
    # import os
    # os.environ["ORACLE_HOME"] = r'F:\soft\setup\oracle\instantclient_11_2'
    user = 'scott'
    password = 'scott'
    host = '192.168.153.134:1521'
    service_name = 'helowinXDB'
    conn_str = f"{user}/{password}@{host}/{service_name}"# ('system/system@172.24.0.64:1521/helowinXDB')
    connect = cx_Oracle.connect(conn_str)
    cursor = connect.cursor()
    cursor.execute('select * from mytesttable')
    print(cursor.fetchall())
test()


参考链接:

cx_Oracle 8 Installation


喜欢本文的大家就点个赞吧,同时也欢迎关注

微信号:小豆君编程分享 (关注后,可加入小豆君交流群进行学习交流,也可第一时间看到最新文章)

头条号:小豆君编程分享

相关文章
|
9天前
|
JSON 数据可视化 API
Python 中调用 DeepSeek-R1 API的方法介绍,图文教程
本教程详细介绍了如何使用 Python 调用 DeepSeek 的 R1 大模型 API,适合编程新手。首先登录 DeepSeek 控制台获取 API Key,安装 Python 和 requests 库后,编写基础调用代码并运行。文末包含常见问题解答和更简单的可视化调用方法,建议收藏备用。 原文链接:[如何使用 Python 调用 DeepSeek-R1 API?](https://apifox.com/apiskills/how-to-call-the-deepseek-r1-api-using-python/)
|
21天前
|
IDE 测试技术 项目管理
【新手必看】PyCharm2025 免费下载安装配置教程+Python环境搭建、图文并茂全副武装学起来才嗖嗖的快,绝对最详细!
PyCharm是由JetBrains开发的Python集成开发环境(IDE),专为Python开发者设计,支持Web开发、调试、语法高亮、项目管理、代码跳转、智能提示、自动完成、单元测试和版本控制等功能。它有专业版、教育版和社区版三个版本,其中社区版免费且适合个人和小型团队使用,包含基本的Python开发功能。安装PyCharm前需先安装Python解释器,并配置环境变量。通过简单的步骤即可在PyCharm中创建并运行Python项目,如输出“Hello World”。
190 13
【新手必看】PyCharm2025 免费下载安装配置教程+Python环境搭建、图文并茂全副武装学起来才嗖嗖的快,绝对最详细!
|
2月前
|
关系型数据库 MySQL 数据库
Python处理数据库:MySQL与SQLite详解 | python小知识
本文详细介绍了如何使用Python操作MySQL和SQLite数据库,包括安装必要的库、连接数据库、执行增删改查等基本操作,适合初学者快速上手。
376 15
|
2月前
|
数据可视化 DataX Python
Seaborn 教程-绘图函数
Seaborn 教程-绘图函数
85 8
|
2月前
Seaborn 教程-主题(Theme)
Seaborn 教程-主题(Theme)
151 7
|
2月前
|
Python
Seaborn 教程-模板(Context)
Seaborn 教程-模板(Context)
56 4
|
2月前
|
数据可视化 Python
Seaborn 教程
Seaborn 教程
63 5
|
3月前
|
Python
SciPy 教程 之 Scipy 显著性检验 9
SciPy 教程之 Scipy 显著性检验第9部分,介绍了显著性检验的基本概念、作用及原理,通过样本信息判断假设是否成立。着重讲解了使用scipy.stats模块进行显著性检验的方法,包括正态性检验中的偏度和峰度计算,以及如何利用normaltest()函数评估数据是否符合正态分布。示例代码展示了如何计算一组随机数的偏度和峰度。
44 1
|
3月前
|
BI Python
SciPy 教程 之 Scipy 显著性检验 8
本教程介绍SciPy中显著性检验的应用,包括如何利用scipy.stats模块进行显著性检验,以判断样本与总体假设间的差异是否显著。通过示例代码展示了如何使用describe()函数获取数组的统计描述信息,如观测次数、最小最大值、均值、方差等。
47 1
|
3月前
|
数据采集 数据可视化 数据挖掘
深入浅出:使用Python进行数据分析的基础教程
【10月更文挑战第41天】本文旨在为初学者提供一个关于如何使用Python语言进行数据分析的入门指南。我们将通过实际案例,了解数据处理的基本步骤,包括数据的导入、清洗、处理、分析和可视化。文章将用浅显易懂的语言,带领读者一步步掌握数据分析师的基本功,并在文末附上完整的代码示例供参考和实践。