网站首页 > 技术文章 正文
这篇文章最早发布在CSDN了,最近想尝试使用一下头条,重新转移过来了。
背景介绍
之前使用的数据库一直是MySql,偶尔使用PostgreSQL,都是利用的数据库连接池使用;
最近需要在Oracle数据库取数据,因此查找了一下连接的方法。网上大部分都是给出的使用cx_Oracle库进行连接,方法也比较简单。但是在进一步了解的时候发现cx_Oracle库 的最新版本已经升级为python-oracledb了;于是简单探究了一下。
python-oracledb驱动程序是一个Python扩展模块,可以访问Oracle数据库。它具有支持Python数据库API v2.0规范的全面功能,具有相当多的附加内容和一些排除项。
python-oracledb驱动程序是cx_Oracle 8.3的重命名的主要版本继承者。
python-oracledb功能亮点:
- 从 PyPI 轻松安装
- 支持多个 Oracle 数据库版本;支持 Python 数据库 API v2.0 规范执行 SQL 和 PL/SQL 语句
- 广泛的 Oracle 数据类型支持,包括 JSON、大型对象 ( 和 ) 和 SQL 对象的绑定CLOBBLOB连接管理,包括连接池Oracle 数据库高可用性功能
- 充分利用 Oracle 网络服务基础架构,包括加密的网络流量
python-oracledb 与 cx_Oracle 使用方法对比
- cx_Oracle使用方法
import cx_Oracle
# 设置连接参数
connection = cx_Oracle.connect(user="hr", password="welcome",
dsn="localhost/orclpdb1")
cursor = connection.cursor()
cursor.execute("""
SELECT first_name, last_name
FROM employees
WHERE department_id = :did AND employee_id > :eid""",
did = 50,
eid = 190)
for fname, lname in cursor:
print("Values:", fname, lname)
- python-oracledb的使用方法
python -m pip install oracledb
默认情况下,python-oracledb在“精简”模式下运行,该模式直接连接到Oracle数据库。此模式不需要 Oracle 客户端库。但是,当python-oracledb使用它们时,可以使用一些其他功能。Python-oracledb在使用Oracle客户端库时被称为“Thick”模式。这两种模式都具有支持 Python 数据库 API v2.0 规范的全面功能。
从默认的精简模式更改为Thick模式需要添加对 oracledb.init_oracle_client() 的调用;当调用init_oracle_client() 时,python-oracledb 使用搜索启发式方式动态加载 Oracle Client 库,使用方法:
import oracledb
oracledb.init_oracle_client(lib_dir=r"D:\instantclient_21_6")
- 独立链接模式
一般方法:
import oracledb
import getpass
userpwd = getpass.getpass("Enter password: ")
connection = oracledb.connect(user="hr", password=userpwd,
dsn="dbhost.example.com/orclpdb")
# 其他功能代码
# 关闭连接
connection.close()
或者可以使用以下方法:
username="hr"
userpwd = os.environ.get("PYTHON_PASSWORD")
host = "localhost"
port = 1521
service_name = "orclpdb"
dsn = f'{username}/{userpwd}@{port}:{host}/{service_name}'
connection = oracledb.connect(dsn)
# 其他功能代码
# 关闭连接
connection.close()
使用连接池的方法
# 初始化连接
pool = oracledb.create_pool(user="hr", password=userpwd, dsn="dbhost.example.com/orclpdb",
min=2, max=5, increment=1)
# Acquire 连接到池
connection = pool.acquire()
# 使用连接池
with connection.cursor() as cursor:
for result in cursor.execute("select * from mytab"):
print(result)
# 释放连接池
pool.release(connection)
# 关闭连接池
pool.close()
猜你喜欢
- 2025-07-10 Oracle 与 Google Cloud 携手大幅扩展多云服务
- 2025-07-10 分享收藏的 oracle 11.2.0.4各平台的下载地址
- 2025-07-10 Oracle 和 Microsoft 推出 Oracle Exadata 数据库服务
- 2025-07-10 Oracle Database@Azure 推进到南美等新区域并增加了新服务
- 2025-07-10 Oracle宣布推出 Oracle Database@AWS 的有限预览版
- 2025-07-10 Oracle与Nextcloud合作,推出主权云上的安全协作平台
- 2025-07-10 NodeRED魔改版连接MsSql、PostgreSQL、MySQL、OracleDB存储无忧
- 2024-10-19 「AWEI」Oracle12c初体验之新建数据库和用户并连接
- 2024-10-19 php7 怎么连接oracle 11g php oracle 连接池
- 2024-10-19 使用JDBC连接ORACLE的三种URL格式
你 发表评论:
欢迎- 07-10Oracle 与 Google Cloud 携手大幅扩展多云服务
- 07-10分享收藏的 oracle 11.2.0.4各平台的下载地址
- 07-10Oracle 和 Microsoft 推出 Oracle Exadata 数据库服务
- 07-10Oracle Database@Azure 推进到南美等新区域并增加了新服务
- 07-10Oracle宣布推出 Oracle Database@AWS 的有限预览版
- 07-10Oracle与Nextcloud合作,推出主权云上的安全协作平台
- 07-10NodeRED魔改版连接MsSql、PostgreSQL、MySQL、OracleDB存储无忧
- 07-10对于企业数据云备份,“多备份”承诺的是成本更低,管理更高效#36氪开放日深圳站#
- 601℃几个Oracle空值处理函数 oracle处理null值的函数
- 593℃Oracle分析函数之Lag和Lead()使用
- 581℃0497-如何将Kerberos的CDH6.1从Oracle JDK 1.8迁移至OpenJDK 1.8
- 578℃Oracle数据库的单、多行函数 oracle执行多个sql语句
- 573℃Oracle 12c PDB迁移(一) oracle迁移到oceanbase
- 566℃【数据统计分析】详解Oracle分组函数之CUBE
- 552℃最佳实践 | 提效 47 倍,制造业生产 Oracle 迁移替换
- 547℃Oracle有哪些常见的函数? oracle中常用的函数
- 最近发表
-
- Oracle 与 Google Cloud 携手大幅扩展多云服务
- 分享收藏的 oracle 11.2.0.4各平台的下载地址
- Oracle 和 Microsoft 推出 Oracle Exadata 数据库服务
- Oracle Database@Azure 推进到南美等新区域并增加了新服务
- Oracle宣布推出 Oracle Database@AWS 的有限预览版
- Oracle与Nextcloud合作,推出主权云上的安全协作平台
- NodeRED魔改版连接MsSql、PostgreSQL、MySQL、OracleDB存储无忧
- 对于企业数据云备份,“多备份”承诺的是成本更低,管理更高效#36氪开放日深圳站#
- 解读丨《归档文件整理规则》— 电子文件元数据存储
- Data Guard跳归档恢复的实践(dataguard failover)
- 标签列表
-
- 前端设计模式 (75)
- 前端性能优化 (51)
- 前端模板 (66)
- 前端跨域 (52)
- 前端缓存 (63)
- 前端aes加密 (58)
- 前端脚手架 (56)
- 前端md5加密 (54)
- 前端路由 (61)
- 前端数组 (73)
- 前端js面试题 (50)
- 前端定时器 (59)
- 前端获取当前时间 (50)
- Oracle RAC (76)
- oracle恢复 (77)
- oracle 删除表 (52)
- oracle 用户名 (80)
- oracle 工具 (55)
- oracle 内存 (55)
- oracle 导出表 (62)
- oracle约束 (54)
- oracle 中文 (51)
- oracle链接 (54)
- oracle的函数 (57)
- 前端调试 (52)
本文暂时没有评论,来添加一个吧(●'◡'●)