【script】python使用cx_Oracle模块访问Oracle

python访问oracle基础代码

'''
cx_Oracle需与python版本一一对应
cx_Oracle下载地址:https://www.lfd.uci.edu/~gohlke/pythonlibs/#cx_oracle
'''

import cx_Oracle  #导入oracle数据库的包

class ORACLE:
    def __init__(self, user, pwd, host, port, service):
        self.user = user
        self.pwd = pwd
        self.host = host
        self.port = port
        self.service = service
        
    def __GetConnect(self):
        '''
        连接数据库
        '''
        try:
            self.conn = cx_Oracle.connect(self.user, self.pwd, self.host + ':' + self.port + '/' + self.service)
            db = self.conn.cursor()
            return db
        except Exception as e:
            raise e
            
    def ExecQuery(self, sql):
        '''
        查询数据库
        '''
        try:
            db = self.__GetConnect()
            db.execute(sql)
            resList = db.fetchall()
            self.conn.close()
            return resList
        except Exception as e:
            raise e

    def ExecNonQuery(self, sql):
        '''
        更新数据库
        '''
        try:
            db = self.__GetConnect()
            db.execute(sql)
            self.conn.commit()
            self.conn.close()
        except Exception as e:
            raise e

# #创建数据库连接对象,要使用哪个数据库需登陆所属用户,否则无法查找到库和表
# orc = ORACLE(user='system', pwd='system', host='127.0.0.1', port='1521', service='XE')

# # 查询数据库示例
# reslist = orc.ExecQuery("select * from \"student\"")
# list(map(print, reslist))

# # 更新数据库示例
# newsql="update \"student\" set \"age\"='18' where \"num\"=3"
# orc.ExecNonQuery(newsql.encode('utf-8'))

访问中出现的报错

ORA-00942: table or view does not exist

oracle数据库是不存在库名的,只有用户和表对象。当表不属于当前登陆的用户,则可能出现该报错

在这里插入图片描述

在这里插入图片描述
找到表所属的用户,登陆对应用户即可;当然,也可以在当前登陆的用户下创建对应的表,下面演示第一种情况

在这里插入图片描述
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值