亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > Python > 正文

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

2020-02-15 21:40:13
字體:
來源:轉載
供稿:網友

本文實例講述了Python3實現的Mysql數據庫操作封裝類。分享給大家供大家參考,具體如下:

#encoding:utf-8#name:mod_db.py'''''使用方法:1.在主程序中先實例化DB Mysql數據庫操作類。   2.使用方法:db=database() db.fetch_all("sql")'''import MySQLdbimport MySQLdb.cursorsimport mod_configimport mod_loggerDB = "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是否存在,然后再讀取。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲欧美精品一区二区| 色偷偷91综合久久噜噜| 97视频人免费观看| 日韩经典中文字幕| 日韩欧美精品网址| 欧美日韩国产一区二区三区| 青青草一区二区| 中文国产成人精品| 国产美女扒开尿口久久久| xxx一区二区| 91久久精品久久国产性色也91| 欧美电影在线观看高清| 亚洲视频在线视频| 91久久久在线| 欧美在线亚洲在线| 欧美激情极品视频| 国产一区二区三区免费视频| 欧美影院成年免费版| 国产精品美女免费视频| 欧美性开放视频| 亚洲国产成人爱av在线播放| 欧美性猛交视频| 性欧美长视频免费观看不卡| 日韩av影片在线观看| 亚洲精品aⅴ中文字幕乱码| 国产激情综合五月久久| 国产69精品99久久久久久宅男| 91免费精品视频| 亚洲人成77777在线观看网| 亚洲第一av网站| 成人h视频在线| 午夜精品久久久久久久白皮肤| 欧美精品九九久久| 欧美精品第一页在线播放| 不卡av在线网站| 国产欧美日韩专区发布| 亚洲美女黄色片| 精品国产老师黑色丝袜高跟鞋| 欧美激情亚洲一区| 久久久91精品国产一区不卡| 欧美在线视频在线播放完整版免费观看| 欧美一级片久久久久久久| 久久久久久久久久久久av| 久久激情视频久久| 91精品视频在线免费观看| 一区二区三区视频观看| 日日狠狠久久偷偷四色综合免费| 国产精品自拍偷拍视频| 91成人国产在线观看| 亚洲人成自拍网站| 欧美日韩国产综合新一区| 日韩精品视频免费在线观看| 国产日韩精品在线| 日本高清不卡的在线| 亚洲香蕉成视频在线观看| 亚洲综合在线小说| 97香蕉超级碰碰久久免费的优势| 中文字幕不卡在线视频极品| 成人av色在线观看| 欧美国产高跟鞋裸体秀xxxhd| 久久成人这里只有精品| 欧美人与性动交a欧美精品| 91在线视频九色| 国产精品吹潮在线观看| 国产91对白在线播放| 最新69国产成人精品视频免费| 国产精品夫妻激情| 超碰日本道色综合久久综合| 久久久久久久av| 亚洲第一色中文字幕| 国产精品视频中文字幕91| 国产精品久久久久久久久久久不卡| 国产精品三级美女白浆呻吟| 在线观看视频99| 久久香蕉国产线看观看av| 亚洲精品久久久一区二区三区| 亚洲国产美女精品久久久久∴| 668精品在线视频| 国产精品吊钟奶在线| 欧美丰满少妇xxxx| 国产成人精品视频在线| 亚洲国产福利在线| 亚洲综合日韩中文字幕v在线| 91精品国产乱码久久久久久久久| 国产一区二区三区在线免费观看| 97精品一区二区视频在线观看| 精品少妇一区二区30p| 欧美精品www| 色哟哟亚洲精品一区二区| 深夜精品寂寞黄网站在线观看| 92裸体在线视频网站| 国产精品久久二区| 久久久久久久国产精品| 亚洲一区二区三区sesese| 亚洲自拍偷拍视频| 日韩av在线网| 欧美极品美女电影一区| 国产免费一区二区三区在线观看| 尤物tv国产一区| 一区二区三区视频免费在线观看| 国产一区在线播放| 亚洲午夜小视频| 亚洲欧美中文日韩v在线观看| 不卡av日日日| 欧美视频免费在线| 日韩av最新在线| 91社区国产高清| 45www国产精品网站| 亚洲aⅴ日韩av电影在线观看| 久99九色视频在线观看| 日韩中文字幕网| 亚洲精品免费一区二区三区| 久久中文字幕国产| 国产亚洲综合久久| 久久久精品国产亚洲| 久久精品亚洲精品| 国产日韩换脸av一区在线观看| 国产精品一二区| 国产成人精品免费视频| 久久亚洲春色中文字幕| 日韩中文字幕av| 欧美亚洲国产视频| 久久深夜福利免费观看| 国产日韩精品电影| 成人亚洲欧美一区二区三区| 午夜精品福利电影| 欧美精品国产精品日韩精品| 日韩欧美一区二区在线| 色久欧美在线视频观看| 久久综合88中文色鬼| 亚洲高清av在线| 7777免费精品视频| 久久久免费观看视频| 亚洲精品短视频| 亚洲爱爱爱爱爱| 国产精品一区二区久久国产| 国产欧美精品一区二区三区-老狼| 国产乱人伦真实精品视频| 91精品免费视频| 精品性高朝久久久久久久| 17婷婷久久www| 久久91精品国产| 日韩成人黄色av| 亚洲精品国产精品国自产观看浪潮| 狠狠色狠狠色综合日日五| 国产日韩欧美在线播放| 亚洲最大福利网| 亚洲人成网站777色婷婷| 久久91超碰青草是什么| 久久精品中文字幕一区| 久久国产精品视频| 国产精品男人的天堂| 久久亚洲精品视频| 欧美第一页在线| 2018国产精品视频| 中文字幕欧美日韩在线| 欧美成人午夜免费视在线看片| 日韩av免费在线看| 97在线视频免费播放| 国产精品永久免费观看| 亚洲人成电影在线| 亚洲性日韩精品一区二区| 亚洲爱爱爱爱爱| 91啪国产在线|