

新闻资讯
技术百科推荐优先使用 oracledb(Oracle 官方推荐、纯 Python 实现、默认 Thin 模式无需客户端),安装 pip install oracledb,支持 Easy Connect 连接字符串、连接池、Thick 模式及常见问题处理。
Python 连接 Oracle 数据库,主流方式是使用 cx_Oracle(旧版)或其继任者 oracledb(Oracle 官方推荐、纯 Python 实现、无需 Oracle 客户端)。推荐优先使用 oracledb,尤其新项目。
执行命令安装:
pip install oracledb
注意:oracledb 无需安装 Oracle Instant Client(除非使用 Thick 模式),默认运行在 Thin 模式,开箱即用。
使用用户名、密码、主机、端口和 SID 或服务名构造连接字符串。常见写法如下:
"username/password@host:port/service_name"
"username/password@//host:port/service_name"
示例代码:
import oracledb连接
conn = oracledb.connect( user="scott", password="tiger", dsn="localhost:1521/orclpdb1" # 或 "localhost:1521/ORCLPDB1" )
创建游标并查询
cursor = conn.cursor() cursor.execute("SELECT * FROM employees WHERE ROWNUM <= 5") for row in cursor: print(row)
c
ursor.close() conn.close()
生产环境建议用连接池提升性能,避免频繁创建/关闭连接:
oracledb.create_pool() 创建连接池pool.acquire(),用完归还:pool.release(conn)
若需兼容旧系统或使用高级功能(如 LDAP、高级队列),可启用 Thick 模式(需先安装 Oracle Instant Client):
oracledb.init_oracle_client(lib_dir="/path/to/instantclient")
DPY-3002(无法解析连接描述符):检查 service_name 是否正确,可用 sqlplus 验证