python mysql操作封装库_Python3实现的Mysql数据库操作封装类

本文实例讲述了Python3实现的Mysql数据库操作封装类。分享给大家供大家参考,具体如下:

#encoding:utf-8

#name:mod_db.py

'''''

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

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

'''

import MySQLdb

import MySQLdb.cursors

import mod_config

import mod_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)

#数据库操作类

class database:

#注,python的self等于其它语言的this

def __init__(self, dbname=None, dbhost=None):

self._logger = logger

#这里的None相当于其它语言的NULL

if dbname is None:

self._dbname = DBNAME

else:

self._dbname = dbname

if dbhost is None:

self._dbhost = DBHOST

else:

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()

#数据库连接

def connectMySQL(self):

conn = False

try:

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,

)

except Exception,data:

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

conn = False

return conn

#获取查询结果集

def fetch_all(self, sql):

res = ''

if(self._conn):

try:

self._cursor.execute(sql)

res = self._cursor.fetchall()

except Exception, data:

res = False

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

return res

def update(self, sql):

flag = False

if(self._conn):

try:

self._cursor.execute(sql)

self._conn.commit()

flag = True

except Exception, data:

flag = False

self._logger.warn("update database exception, %s" % data)

return flag

#关闭数据库连接

def close(self):

if(self._conn):

try:

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

self._cursor.close()

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

self._conn.close()

except Exception, data:

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

这段代码需要注意几个地方:

1.数据库配置文件变量放在类外面,只在模块被载入的时候读一次,在使用数据库类时,无需再读取。这样有一个好处就是减少了IO的操作。如果是脚本程序需要不停的扫数据库,放在类初始化的时候读数据库配置,那么很有可能造成IO错误,或者读到的section为空,从而导致程序down掉。不好的地方就是如果修改了config,无法及时更新。不过一般程序部署后,不会随意修改config文件,或者在修改config文件后,重新启动程序。不过从程序的健壮性考虑,可以在可能会抛出异常的地方try,catch一下,更好的办法是,在mod_config.py模块中判断一下该section和key是否存在,然后再读取。

2.数据库类在初始化的时候,就将游标赋给它,而不是在进行数据库操作的时候再寻找游标。

PS:在主程序中先实例化DB Mysql数据库操作类。再进行方法使用!

更多关于Python相关内容感兴趣的读者可查看本站专题:《Python+MySQL数据库程序设计入门教程》、《Python常见数据库操作技巧汇总》、《Python数学运算技巧总结》、《Python数据结构与算法教程》、《Python函数使用技巧总结》、《Python字符串操作技巧汇总》、《Python入门与进阶经典教程》及《Python文件与目录操作技巧汇总》

希望本文所述对大家Python程序设计有所帮助。

本文标题: Python3实现的Mysql数据库操作封装类

本文地址: http://www.cppcns.com/shujuku/mysql/229603.html

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值