Python3实现的Mysql数据库操作封装类


Posted in Python onJune 06, 2018

本文实例讲述了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 相关文章推荐
Python中__call__用法实例
Aug 29 Python
Python输出9*9乘法表的方法
May 25 Python
Python实现Sqlite将字段当做索引进行查询的方法
Jul 21 Python
python递归查询菜单并转换成json实例
Mar 27 Python
Python实现图片滑动式验证识别方法
Nov 09 Python
python+opencv实现动态物体追踪
Jan 09 Python
python2.7+selenium2实现淘宝滑块自动认证功能
Feb 24 Python
django.db.utils.ProgrammingError: (1146, u“Table‘’ doesn’t exist”)问题的解决
Jul 13 Python
Python线程同步的实现代码
Oct 03 Python
10分钟教你用Python实现微信自动回复功能
Nov 28 Python
解决tensorboard多个events文件显示紊乱的问题
Feb 15 Python
PyTorch预训练Bert模型的示例
Nov 17 Python
python操作redis方法总结
Jun 06 #Python
目前最全的python的就业方向
Jun 05 #Python
python多进程提取处理大量文本的关键词方法
Jun 05 #Python
使用python进行文本预处理和提取特征的实例
Jun 05 #Python
python 用正则表达式筛选文本信息的实例
Jun 05 #Python
python和shell获取文本内容的方法
Jun 05 #Python
python 查找文件名包含指定字符串的方法
Jun 05 #Python
You might like
PHP.MVC的模板标签系统(四)
2006/09/05 PHP
php页面防重复提交方法总结
2013/11/25 PHP
php实现文件上传及头像预览功能
2017/01/15 PHP
php实现的后台表格分页功能示例
2017/10/23 PHP
Document对象内容集合(比较全)
2010/09/06 Javascript
Json对象替换字符串占位符实现代码
2010/11/17 Javascript
一个轻量级的javascript库 pj介绍
2010/12/19 Javascript
JS加jquery简单实现标签元素的显示或隐藏
2013/09/23 Javascript
node.js中的fs.chmod方法使用说明
2014/12/18 Javascript
JavaScript中原型和原型链详解
2015/02/11 Javascript
基于JS2Image实现圣诞树代码
2015/12/24 Javascript
详解Vue-基本标签和自定义控件
2017/03/24 Javascript
JS写谷歌浏览器chrome的外挂实例
2018/01/11 Javascript
nodejs结合socket.io实现websocket通信功能的方法
2018/01/12 NodeJs
图文介绍Vue父组件向子组件传值
2018/02/17 Javascript
JS实现访问DOM对象指定节点的方法示例
2018/04/04 Javascript
vue中动态添加class类名的方法
2018/09/05 Javascript
Angular ElementRef简介及其使用
2018/10/01 Javascript
如何解决.vue文件url引用文件的问题
2019/01/18 Javascript
vue项目部署到nginx/tomcat服务器的实现
2019/08/26 Javascript
JavaScript设计模式--简单工厂模式实例分析【XHR工厂案例】
2020/05/23 Javascript
用Python实现一个简单的线程池
2015/04/07 Python
Windows下Python使用Pandas模块操作Excel文件的教程
2016/05/31 Python
python 读写txt文件 json文件的实现方法
2016/10/22 Python
深入分析python中整型不会溢出问题
2018/06/18 Python
Python字符串、整数、和浮点型数相互转换实例
2018/08/04 Python
使用EduBlock轻松学习Python编程
2018/10/08 Python
Python中那些 Pythonic的写法详解
2019/07/02 Python
django自定义模板标签过程解析
2019/12/14 Python
jupyter notebook 重装教程
2020/04/16 Python
欧洲最古老的鞋厂:Peter Kaiser
2019/11/05 全球购物
我想声明一个指针并为它分配一些空间, 但却不行。这些代码有什么 问题?char *p; *p = malloc(10);
2016/10/06 面试题
会计专业毕业生自荐信范文
2013/12/20 职场文书
暑假家长评语大全
2014/04/17 职场文书
2014乡镇领导班子四风对照检查材料思想汇报
2014/10/05 职场文书
综合办公室岗位职责
2015/04/11 职场文书