python采用jdbc连接oracle

背景

之前写了一篇python采用jdbc连接kerberos认证的hive,本文是采用LDAP用户名和密码的方式连接Oracle,并且提供一种自动关闭游标和数据库连接的方式,方便使用;

方法

具体代码如下:

python 复制代码
class OracleConn:
    def __init__(self, username, password, url):
        self.username = username
        self.password =password
        self.url = url
        self.conn = None
        self.cursor = None
    def connect_oracle(self):
        import jaydebeapi
        self.conn = jaydebeapi.connect("oracle.jdbc.OracleDriver", self.url,
                                       [self.username, self.password],
                                       jars=["./oracle-driver-ojdbc.jar"]
                                       )
        self.cursor = self.conn.cursor()
    def __enter__(self):
        self.connect_oracle()
        return (self.conn, self.cursor)

    def __exit__(self, exc_type, exc_val, exc_tb):
        if self.cursor is not None:
            self.cursor.close()
        if self.conn is not None:
            self.conn.close()

采用如上的方式,我们创建了oracle的Conn和cursor,可以提供具体的代码;

ini 复制代码
username=""
password=""
url=""
with OracleConn(username, password, url) as (conn,cursor):
    cursor.execute("select * from xxx")
    result=cursor.fetchall()
    for r in result:
        print(r)

采用这种方式,我们可以不用自己释放数据库连接,在程序执行完成之后自动释放; 需要注意的是,我们在执行连接时需要加载oracle的jdbc的jar包,正常情况下,使用jaydebeapi执行一个进程时,只加载一次jdbc的jar包,第二次加载不生效,因此如果一个程序中要同时连接两个不同类型的数据库,要加载两个不同的jdbc的jar包时,在第一次连接时就应该加载所有的jdbc jar包,不然连接第二种类型的数据库时会报错;

相关推荐
酷飞飞1 小时前
Python网络与多任务编程:TCP/UDP实战指南
网络·python·tcp/ip
数字化顾问2 小时前
Python:OpenCV 教程——从传统视觉到深度学习:YOLOv8 与 OpenCV DNN 模块协同实现工业缺陷检测
python
学生信的大叔3 小时前
【Python自动化】Ubuntu24.04配置Selenium并测试
python·selenium·自动化
诗句藏于尽头4 小时前
Django模型与数据库表映射的两种方式
数据库·python·django
智数研析社4 小时前
9120 部 TMDb 高分电影数据集 | 7 列全维度指标 (评分 / 热度 / 剧情)+API 权威源 | 电影趋势分析 / 推荐系统 / NLP 建模用
大数据·人工智能·python·深度学习·数据分析·数据集·数据清洗
扯淡的闲人4 小时前
多语言编码Agent解决方案(5)-IntelliJ插件实现
开发语言·python
moxiaoran57534 小时前
Flask学习笔记(一)
后端·python·flask
秋氘渔5 小时前
迭代器和生成器的区别与联系
python·迭代器·生成器·可迭代对象
Gu_shiwww5 小时前
数据结构8——双向链表
c语言·数据结构·python·链表·小白初步
Dxy12393102167 小时前
python把文件从一个文件复制到另一个文件夹
开发语言·python