欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Python3實現的Mysql數據庫操作封裝類

 更新時間:2018年06月06日 08:33:57   作者:除了玩_什么都不會  
這篇文章主要介紹了Python3實現的Mysql數據庫操作封裝類,涉及Python針對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程序設計有所幫助。

相關文章

  • 編寫Python腳本批量下載DesktopNexus壁紙的教程

    編寫Python腳本批量下載DesktopNexus壁紙的教程

    這篇文章主要介紹了編寫Python腳本批量下載DesktopNexus壁紙的教程,相較于普通的爬蟲抓取,本文的下載壁紙教程還包括了設置所要下載的分辨率等功能的實現,需要的朋友可以參考下
    2015-05-05
  • Python PyQt5實現的簡易計算器功能示例

    Python PyQt5實現的簡易計算器功能示例

    這篇文章主要介紹了Python PyQt5實現的簡易計算器功能,涉及Python PyQt5事件響應及數學運算等相關操作技巧,需要的朋友可以參考下
    2017-08-08
  • OpenCV實現機器人對物體進行移動跟隨的方法實例

    OpenCV實現機器人對物體進行移動跟隨的方法實例

    這篇文章主要給大家介紹了關于OpenCV實現機器人對物體進行移動跟隨的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-11-11
  • Python的mysql數據庫的更新如何實現

    Python的mysql數據庫的更新如何實現

    這篇文章主要介紹了Python的mysql數據庫的更新如何實現的相關資料,這里提供實例代碼,幫助大家理解應用這部分知識,需要的朋友可以參考下
    2017-07-07
  • Python數據可視化JupyterNotebook繪圖生成高清圖片

    Python數據可視化JupyterNotebook繪圖生成高清圖片

    這篇文章主要為大家介紹了Python數據可視化中如何利用Jupyter Notebook繪圖生成高清圖片,有需要的朋友可以借鑒參考下,希望能夠有所幫助
    2021-09-09
  • Python實戰(zhàn)項目之MySQL tkinter pyinstaller實現學生管理系統(tǒng)

    Python實戰(zhàn)項目之MySQL tkinter pyinstaller實現學生管理系統(tǒng)

    讀萬卷書不如行萬里路,只學書上的理論是遠遠不夠的,只有在實戰(zhàn)中才能獲得能力的提升,本篇文章手把手帶你用MySQL、tkinter、 pyinstaller實現一個學生管理系統(tǒng),大家可以通過案例查缺補漏,提升水平
    2021-10-10
  • python去除字符串中的換行符

    python去除字符串中的換行符

    這篇文章主要介紹了python去除字符串中的換行符的相關資料,然后在文章下面給大家補充介紹了python去除空格和換行符的方法,需要的朋友可以參考下
    2017-10-10
  • Python中創(chuàng)建表格詳細過程

    Python中創(chuàng)建表格詳細過程

    這篇文章主要介紹了Python中創(chuàng)建表格,在python中使用tabulate庫來創(chuàng)建表格,并針對輸出形式進行不斷改進來美化輸出效果,并給出了代碼示例。需要的小伙伴可以參考一下
    2022-02-02
  • Python發(fā)送form-data請求及拼接form-data內容的方法

    Python發(fā)送form-data請求及拼接form-data內容的方法

    這篇文章主要介紹了Python發(fā)送form-data請求及拼接form-data內容的方法,文中采用的是requests的方式發(fā)送multipart/form-data請求,需要的朋友可以參考下
    2016-03-03
  • flask 實現上傳圖片并縮放作為頭像的例子

    flask 實現上傳圖片并縮放作為頭像的例子

    今天小編就為大家分享一篇flask 實現上傳圖片并縮放作為頭像的例子,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-01-01

最新評論