Python3實(shí)現(xiàn)的Mysql數(shù)據(jù)庫(kù)操作封裝類
本文實(shí)例講述了Python3實(shí)現(xiàn)的Mysql數(shù)據(jù)庫(kù)操作封裝類。分享給大家供大家參考,具體如下:
#encoding:utf-8 #name:mod_db.py ''''' 使用方法:1.在主程序中先實(shí)例化DB Mysql數(shù)據(jù)庫(kù)操作類。 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) #數(shù)據(jù)庫(kù)操作類 class database: #注,python的self等于其它語(yǔ)言的this def __init__(self, dbname=None, dbhost=None): self._logger = logger #這里的None相當(dāng)于其它語(yǔ)言的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() #數(shù)據(jù)庫(kù)連接 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 #獲取查詢結(jié)果集 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 #關(guān)閉數(shù)據(jù)庫(kù)連接 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)))
這段代碼需要注意幾個(gè)地方:
1.數(shù)據(jù)庫(kù)配置文件變量放在類外面,只在模塊被載入的時(shí)候讀一次,在使用數(shù)據(jù)庫(kù)類時(shí),無(wú)需再讀取。這樣有一個(gè)好處就是減少了IO的操作。如果是腳本程序需要不停的掃數(shù)據(jù)庫(kù),放在類初始化的時(shí)候讀數(shù)據(jù)庫(kù)配置,那么很有可能造成IO錯(cuò)誤,或者讀到的section為空,從而導(dǎo)致程序down掉。不好的地方就是如果修改了config,無(wú)法及時(shí)更新。不過(guò)一般程序部署后,不會(huì)隨意修改config文件,或者在修改config文件后,重新啟動(dòng)程序。不過(guò)從程序的健壯性考慮,可以在可能會(huì)拋出異常的地方try,catch一下,更好的辦法是,在mod_config.py模塊中判斷一下該section和key是否存在,然后再讀取。
2.數(shù)據(jù)庫(kù)類在初始化的時(shí)候,就將游標(biāo)賦給它,而不是在進(jìn)行數(shù)據(jù)庫(kù)操作的時(shí)候再尋找游標(biāo)。
PS:在主程序中先實(shí)例化DB Mysql數(shù)據(jù)庫(kù)操作類。再進(jìn)行方法使用!
更多關(guān)于Python相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Python+MySQL數(shù)據(jù)庫(kù)程序設(shè)計(jì)入門教程》、《Python常見(jiàn)數(shù)據(jù)庫(kù)操作技巧匯總》、《Python數(shù)學(xué)運(yùn)算技巧總結(jié)》、《Python數(shù)據(jù)結(jié)構(gòu)與算法教程》、《Python函數(shù)使用技巧總結(jié)》、《Python字符串操作技巧匯總》、《Python入門與進(jìn)階經(jīng)典教程》及《Python文件與目錄操作技巧匯總》
希望本文所述對(duì)大家Python程序設(shè)計(jì)有所幫助。
相關(guān)文章
編寫Python腳本批量下載DesktopNexus壁紙的教程
這篇文章主要介紹了編寫Python腳本批量下載DesktopNexus壁紙的教程,相較于普通的爬蟲(chóng)抓取,本文的下載壁紙教程還包括了設(shè)置所要下載的分辨率等功能的實(shí)現(xiàn),需要的朋友可以參考下2015-05-05Python PyQt5實(shí)現(xiàn)的簡(jiǎn)易計(jì)算器功能示例
這篇文章主要介紹了Python PyQt5實(shí)現(xiàn)的簡(jiǎn)易計(jì)算器功能,涉及Python PyQt5事件響應(yīng)及數(shù)學(xué)運(yùn)算等相關(guān)操作技巧,需要的朋友可以參考下2017-08-08OpenCV實(shí)現(xiàn)機(jī)器人對(duì)物體進(jìn)行移動(dòng)跟隨的方法實(shí)例
這篇文章主要給大家介紹了關(guān)于OpenCV實(shí)現(xiàn)機(jī)器人對(duì)物體進(jìn)行移動(dòng)跟隨的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-11-11Python的mysql數(shù)據(jù)庫(kù)的更新如何實(shí)現(xiàn)
這篇文章主要介紹了Python的mysql數(shù)據(jù)庫(kù)的更新如何實(shí)現(xiàn)的相關(guān)資料,這里提供實(shí)例代碼,幫助大家理解應(yīng)用這部分知識(shí),需要的朋友可以參考下2017-07-07Python數(shù)據(jù)可視化JupyterNotebook繪圖生成高清圖片
這篇文章主要為大家介紹了Python數(shù)據(jù)可視化中如何利用Jupyter Notebook繪圖生成高清圖片,有需要的朋友可以借鑒參考下,希望能夠有所幫助2021-09-09Python實(shí)戰(zhàn)項(xiàng)目之MySQL tkinter pyinstaller實(shí)現(xiàn)學(xué)生管理系統(tǒng)
讀萬(wàn)卷書(shū)不如行萬(wàn)里路,只學(xué)書(shū)上的理論是遠(yuǎn)遠(yuǎn)不夠的,只有在實(shí)戰(zhàn)中才能獲得能力的提升,本篇文章手把手帶你用MySQL、tkinter、 pyinstaller實(shí)現(xiàn)一個(gè)學(xué)生管理系統(tǒng),大家可以通過(guò)案例查缺補(bǔ)漏,提升水平2021-10-10Python中創(chuàng)建表格詳細(xì)過(guò)程
這篇文章主要介紹了Python中創(chuàng)建表格,在python中使用tabulate庫(kù)來(lái)創(chuàng)建表格,并針對(duì)輸出形式進(jìn)行不斷改進(jìn)來(lái)美化輸出效果,并給出了代碼示例。需要的小伙伴可以參考一下2022-02-02Python發(fā)送form-data請(qǐng)求及拼接form-data內(nèi)容的方法
這篇文章主要介紹了Python發(fā)送form-data請(qǐng)求及拼接form-data內(nèi)容的方法,文中采用的是requests的方式發(fā)送multipart/form-data請(qǐng)求,需要的朋友可以參考下2016-03-03flask 實(shí)現(xiàn)上傳圖片并縮放作為頭像的例子
今天小編就為大家分享一篇flask 實(shí)現(xiàn)上傳圖片并縮放作為頭像的例子,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-01-01