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导入txt数据到mysql的方法
Apr 08 Python
pymssql数据库操作MSSQL2005实例分析
May 25 Python
Python运算符重载用法实例
May 28 Python
在Python的Django框架中simple-todo工具的简单使用
May 30 Python
使用Python和xlwt向Excel文件中写入中文的实例
Apr 21 Python
python使用turtle库绘制时钟
Mar 25 Python
使用Python对微信好友进行数据分析
Jun 27 Python
python+flask实现API的方法
Nov 21 Python
PyQt5 窗口切换与自定义对话框的实例
Jun 20 Python
Python编写带选项的命令行程序方法
Aug 13 Python
Pytorch之卷积层的使用详解
Dec 31 Python
pytorch 使用加载训练好的模型做inference
Feb 20 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
自己动手,丰衣足食 - 短波框形天线制作
2021/03/01 无线电
php下用GD生成生成缩略图的两个选择和区别
2007/04/17 PHP
php+mysql查询优化简单实例
2015/01/13 PHP
Thinkphp 框架配置操作之配置加载与读取配置实例分析
2020/05/15 PHP
JSON扫盲帖 JSON.as类教程
2009/02/16 Javascript
JavaScript下通过的XMLHttpRequest发送请求的代码
2011/06/28 Javascript
40个有创意的jQuery图片、内容滑动及弹出插件收藏集之一
2011/12/31 Javascript
JavaScript和CSS通过expression实现Table居中显示
2013/06/28 Javascript
javascript函数式编程程序员的工具集
2015/10/11 Javascript
浅析JavaScript作用域链、执行上下文与闭包
2016/02/01 Javascript
Bootstrap入门教程一Hello Bootstrap初识
2017/03/02 Javascript
JavaScript对象_动力节点Java学院整理
2017/06/23 Javascript
在vue中实现简单页面逆传值的方法
2017/11/27 Javascript
利用Javascript实现一套自定义事件机制
2017/12/14 Javascript
js中let和var定义变量的区别
2018/02/08 Javascript
MVVM框架下实现分页功能示例
2018/06/14 Javascript
vue+iview分页组件的封装
2020/11/17 Vue.js
vue绑定class的三种方法
2020/12/24 Vue.js
python操作MySQL数据库的方法分享
2012/05/29 Python
Python爬虫抓取手机APP的传输数据
2016/01/22 Python
基于python内置函数与匿名函数详解
2018/01/09 Python
Tensorflow之Saver的用法详解
2018/04/23 Python
利用Python如何实现一个小说网站雏形
2018/11/23 Python
使用Python给头像加上圣诞帽或圣诞老人小图标附源码
2019/12/25 Python
树莓派4B安装Tensorflow的方法步骤
2020/07/16 Python
迪卡侬(Decathlon)加拿大官网:源自法国的运动专业超市
2020/11/22 全球购物
介绍一下Java的事务处理
2012/12/07 面试题
如何执行一个shell程序
2012/11/23 面试题
甜品店的创业计划书范文
2014/01/02 职场文书
竞选班委演讲稿
2014/04/28 职场文书
大班上学期幼儿评语
2014/04/30 职场文书
水电站项目建议书
2014/05/12 职场文书
二年级语文下册复习计划
2015/01/19 职场文书
工厂员工辞职信范文
2015/05/12 职场文书
Python各协议下socket黏包问题原理
2022/04/12 Python
win10频率超出范围怎么办?win10老显示超出工作频率范围的解决方法
2022/07/07 数码科技