模块和包.DBUtils

简单说明:

此模块儿是一套数据库连接池包,并允许对非线程安全的数据库接口进行线程安全封装,目前主要提供PersistentDB 线程专用的数据库连接,并自动管理连接和提供PooledDB线程之间可共享数据库连接并自动管理连接,经过测试PersistentDB速度最高,但在某些特殊情况下数据库的连接过程可能异常缓慢,而PooledDB可提供连接平均时间较短的管理方式(SQLite数据库只能使用PersistentDB作为连接池)


连接池子:

from DBUtils.PooledDB import PooledDB

pool = PooledDB (creator=None, mincached=0, maxcached=0, maxshared=0, maxconnections=0, blocking=False, maxusage=None, setsession=None, reset=True, failures=None, ping=1, *args, **kwargs)

说明: creator为数据库接口,可为MySQLdb,mincached为启动时开启的空连接数量,maxcached为连接池最大可用的连接数量,maxshared为连接池最大可共享连接数量,maxconnections为最大允许连接数量,blocking为达到最大数量时是否阻塞,maxusage单个连接最大复用次数,setsession用于传递到数据库的准备会话,如["set name UTF-8"]


常用方法:

pool.connection() -> connect object

说明: 从pool连接池中弹出并返回一个连接对象,此对象的属性和方法其实就是creator数据库接口创建的连接的属性和方法


你可能感兴趣的:(模块和包.DBUtils)