python数据库操作封装_Python一个简单的数据库类封装

#encoding:utf-8#name:mod_db.py

'''

使用方法:1.在主程序中先实例化DB Mysql数据库操作类。

2.使用方法:db=database() db.fetch_all("sql")

'''

importMySQLdbimportMySQLdb.cursorsimportmod_configimportmod_logger

DB= "database"LOGPATH= mod_config.getConfig('path', 'logpath') + 'database.log'DBNAME= mod_config.getConfig(DB, 'dbname')

DBHOST= mod_config.getConfig(DB, 'dbhost')

DBUSER= mod_config.getConfig(DB, 'dbuser')

DBPWD= mod_config.getConfig(DB, 'dbpassword')

DBCHARSET= mod_config.getConfig(DB, 'dbcharset')

DBPORT= mod_config.getConfig(DB, "dbport")

logger=mod_logger.logger(LOGPATH)

#数据库操作类classdatabase:

#注,python的self等于其它语言的thisdef __init__(self, dbname=None, dbhost=None):

self._logger=logger

#这里的None相当于其它语言的NULLif dbname isNone:

self._dbname=DBNAMEelse:

self._dbname=dbnameif dbhost isNone:

self._dbhost=DBHOSTelse:

self._dbhost=dbhost

self._dbuser=DBUSER

self._dbpassword=DBPWD

self._dbcharset=DBCHARSET

self._dbport=int(DBPORT)

self._conn=self.connectMySQL()if(self._conn):

self._cursor=self._conn.cursor()#数据库连接

defconnectMySQL(self):

conn=Falsetry:

conn= MySQLdb.connect(host=self._dbhost,

user=self._dbuser,

passwd=self._dbpassword,

db=self._dbname,

port=self._dbport,

cursorclass=MySQLdb.cursors.DictCursor,

charset=self._dbcharset,

)exceptException,data:

self._logger.error("connect database failed, %s" %data)

conn=Falsereturnconn#获取查询结果集

deffetch_all(self, sql):

res= ''

if(self._conn):try:

self._cursor.execute(sql)

res=self._cursor.fetchall()exceptException, data:

res=False

self._logger.warn("query database exception, %s" %data)returnresdefupdate(self, sql):

flag=Falseif(self._conn):try:

self._cursor.execute(sql)

self._conn.commit()

flag=TrueexceptException, data:

flag=False

self._logger.warn("update database exception, %s" %data)returnflag#关闭数据库连接

defclose(self):if(self._conn):try:if(type(self._cursor)=='object'):

self._cursor.close()if(type(self._conn)=='object'):

self._conn.close()exceptException, data:

self._logger.warn("close database exception, %s,%s,%s" % (data, type(self._cursor), type(self._conn)))

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值