python oracle连接池_使用PooledDB连接池cx_Oracle操作Oracle数据库通用封装

本文介绍了一个Python类Ora,用于通过PooledDB连接池管理cx_Oracle连接,实现对Oracle数据库的增删改查和备份操作。通过示例代码展示了如何初始化连接池、执行SQL、分页查询等功能。
摘要由CSDN通过智能技术生成

1.[代码][Python]代码

#coding=utf-8

'''

oracle 数据库操作封装 by zhengyangbo 20160329

'''

import sys

import config

import cx_Oracle

from datetime import datetime

from DBUtils.PooledDB import PooledDB

class Ora():

__pool = None #连接池对象

def __init__(self,db_info=None):

#连接池方式

self.db_info = db_info

self.conn = Ora.__getConn(db_info)

self.cursor = self.conn.cursor()

@staticmethod

def __getConn(db_info):

#静态方法,从连接池中取出连接

if Ora.__pool is None:

__pool = PooledDB(cx_Oracle,

user = db_info['user'],

password = db_info['pwd'],

dsn = "%s:%s/%s" %(db_info['host'],db_info['port'],db_info['sid']),

mincached=20,

maxcached=200)

return __pool.connection()

#查询表的所有列

def columns(self,table):

sql = ["select lower(column_name)column_name \

from user_tab_columns where table_name=upper('%(table)s')"]

rows = self.query(''.join(sql) % locals())

col_list = [k["column_name"] for k in rows]

#['sjhm', 'a', 'b', 'c', 'd', 'e', 'f', 'g', 'status']

return col_list

#根据表自动创建参数字典

def create_params(self,table,args = {}):

col_list = self.columns(table)

params = {}

for k in col_list:

if args.has_key(k):

params[k] = args[k]

return params

#执行sql

def execute(self, sql, args = {}):

try:

return self.cursor.execute(sql, args)

except Exception,e:

self.close()

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值