1. #encoding:utf-8
  2. #name:mod_db.py
  3. '''
    使用方法:1.在主程序中先实例化DB Mysql数据库操作类。
          2.使用方法:db=database()  db.fetch_all("sql")
    '''
  4. import MySQLdb
  5. import MySQLdb.cursors
  6. import mod_config
  7. import mod_logger
  8.  
  9. DB = "database"
  10. LOGPATH = mod_config.getConfig('path', 'logpath') + 'database.log'
  11. DBNAME = mod_config.getConfig(DB, 'dbname')
  12. DBHOST = mod_config.getConfig(DB, 'dbhost')
  13. DBUSER = mod_config.getConfig(DB, 'dbuser')
  14. DBPWD = mod_config.getConfig(DB, 'dbpassword')
  15. DBCHARSET = mod_config.getConfig(DB, 'dbcharset')
  16. DBPORT = mod_config.getConfig(DB, "dbport")
  17.  
  18. logger = mod_logger.logger(LOGPATH)
  19. #数据库操作类
  20. class database:
    #注,python的self等于其它语言的this
  21. def __init__(self, dbname=None, dbhost=None):
  22. self._logger = logger
      #这里的None相当于其它语言的NULL
  23. if dbname is None:
  24. self._dbname = DBNAME
  25. else:
  26. self._dbname = dbname
  27. if dbhost is None:
  28. self._dbhost = DBHOST
  29. else:
  30. self._dbhost = dbhost
  31.  
  32. self._dbuser = DBUSER
  33. self._dbpassword = DBPWD
  34. self._dbcharset = DBCHARSET
  35. self._dbport = int(DBPORT)
  36. self._conn = self.connectMySQL()
  37.  
  38. if(self._conn):
  39. self._cursor = self._conn.cursor()
  40.  
  41. #数据库连接
  42. def connectMySQL(self):
  43. conn = False
  44. try:
  45. conn = MySQLdb.connect(host=self._dbhost,
  46. user=self._dbuser,
  47. passwd=self._dbpassword,
  48. db=self._dbname,
  49. port=self._dbport,
  50. cursorclass=MySQLdb.cursors.DictCursor,
  51. charset=self._dbcharset,
  52. )
  53. except Exception,data:
  54. self._logger.error("connect database failed, %s" % data)
  55. conn = False
  56. return conn
  57.  
  58. #获取查询结果集
  59. def fetch_all(self, sql):
  60. res = ''
  61. if(self._conn):
  62. try:
  63. self._cursor.execute(sql)
  64. res = self._cursor.fetchall()
  65. except Exception, data:
  66. res = False
  67. self._logger.warn("query database exception, %s" % data)
  68. return res
  69.  
  70. def update(self, sql):
  71. flag = False
  72. if(self._conn):
  73. try:
  74. self._cursor.execute(sql)
  75. self._conn.commit()
  76. flag = True
  77. except Exception, data:
  78. flag = False
  79. self._logger.warn("update database exception, %s" % data)
  80.  
  81. return flag
  82.  
  83. #关闭数据库连接
  84. def close(self):
  85. if(self._conn):
  86. try:
  87. if(type(self._cursor)=='object'):
  88. self._cursor.close()
  89. if(type(self._conn)=='object'):
  90. self._conn.close()
  91. except Exception, data:
  92. 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一个简单的数据库类封装的更多相关文章

  1. python+selenium之自定义封装一个简单的Log类

    python+selenium之自定义封装一个简单的Log类 一. 问题分析: 我们需要封装一个简单的日志类,主要有以下内容: 1. 生成的日志文件格式是 年月日时分秒.log 2. 生成的xxx.l ...

  2. Python之自定义封装一个简单的Log类

    参考:http://www.jb51.net/article/42626.htm 参考:http://blog.csdn.net/u011541946/article/details/70198676 ...

  3. Python+Selenium中级篇之8-Python自定义封装一个简单的Log类《转载》

    Python+Selenium中级篇之8-Python自定义封装一个简单的Log类: https://blog.csdn.net/u011541946/article/details/70198676

  4. VC++ 一个简单的Log类

    在软件开发中,为程序建立Log日志是很必要的,它可以记录程序运行的状态以及出错信息,方便维护和调试. 下面实现了一个简单的Log类,使用非常简单,仅供参考. // CLogHelper.h : hea ...

  5. C++定义一个简单的Computer类

    /*定义一个简单的Computer类 有数据成员芯片(cpu).内存(ram).光驱(cdrom)等等, 有两个公有成员函数run.stop.cpu为CPU类的一个对象, ram为RAM类的一个对象, ...

  6. Python—一个简单搜索引擎索引库

    因为课业要求,搭建一个简单的搜索引擎,找了一些相关资料并进行了部分优化(坑有点多) 一.数据 数据是网络上爬取的旅游相关的攻略页面 这个是travels表,在索引中主要用到id和url两个字段. 页面 ...

  7. python -----一个简单的小程序(监控电脑内存,cpu,硬盘)

    一个简单的小程序 用函数实现!~~ 实现: cpu 使用率大于百分之50 时  ,  C 盘容量不足5 G 时, 内存 低于2G 时. 出现以上其中一种情况,发送自动报警邮件! 主要运用 到了两个 模 ...

  8. Java下一个简单的数据库分库帮助类

    简介    前面两篇文章主要讲了数据库读写分离和分表分库的一些问题,这篇文章主要讲一下我个人实现的一个分表分库项目.     在此之前,我有写过一个.Net的分库,最近在做Java的项目,就顺便做出一 ...

  9. 通过一个简单的数据库操作类了解PHP链式操作的实现

    class Model{ public $table; //操作的表; private $opt; //查询的参数; private $pri; //表的主键; private $lastSql; / ...

随机推荐

  1. Knockout开发中文API系列1

    从本节开始介绍关于KnockoutJs相关的内容,本节主要介绍knockoutjs一些重要特性与优点,以及它与Jquery等框架库之间的区别. 1.Knockout.js是什么? Knockout是一 ...

  2. jmx学习

    原文地址:https://www.cnblogs.com/dongguacai/p/5900507.html 一.JMX的定义 JMX(Java Management Extensions)是一个为应 ...

  3. php 验证码代码

    1.js代码 function fleshVerify(type){ //重载验证码 var timenow = new Date().getTime(); if (type) { $('verify ...

  4. android开发(42) 使用andorid操作蓝牙打印机

    最近接到一个需求,使用android发起打印任务,通过蓝牙连接打印机.条件如下: 打印机:南京富士通DPK760E,具有蓝牙功能 Android手机:普通手机,Android 4.4版本,具有蓝牙功能 ...

  5. name是个特殊的变量名吗

    这是为什么?求大神

  6. dapper支持操作函数和事物

    dapper除了支持基础的CURD.存储过程以外,还支持操作函数和事物. dapper操作函数的代码如下: using Dapper; using System; using System.Colle ...

  7. NetBeans Support Weblog

    https://blogs.oracle.com/NetBeansSupport/entry/tomcat_log_files ———————————————————————————————————— ...

  8. php 批量修改文件格式或重命名

    <?php /** * 批量修改文件后缀名 * @param $path 文件夹路径 * @param $sext 原文件后缀名 ($sext=all说明整个目录的所有文件) * @param ...

  9. Sword protobuf学习四

    #include <iostream> #include <string> #include <sys/types.h> /* See NOTES */ #incl ...

  10. Android 软键盘弹出与关闭监听

    private void listenerSoftInput() { final View activityRootView = findViewById(R.id.activityRoot); ac ...