Python支持通過(guò)多種方式訪問(wèn)MySQL數(shù)據(jù)庫(kù)。可能有些剛?cè)腴T的朋友們對(duì)Python訪問(wèn)MySQL數(shù)據(jù)庫(kù)還不是很熟悉,故計(jì)劃對(duì)Python訪問(wèn)MySQL數(shù)據(jù)庫(kù)的這幾種方式分別作一介紹。
本文以windows平臺(tái)上開發(fā)為例進(jìn)行講解,相關(guān)基本開發(fā)環(huán)境如下:
(1) Windows 7 (64位)
(2) MySQL 8.0.21
(3) Python 3.8.5
(4) mysqlclient 2.0.1
本次分享的內(nèi)容目錄如下:
前言
1. MySQLdb 介紹
2. MySQLdb 安裝
3. MySQLdb 示例代碼
結(jié)束語(yǔ)
1. MySQLdb 簡(jiǎn)介
MySQLdb曾經(jīng)是一款流行的可以使Python連接到MySQL的驅(qū)動(dòng)接口,它基于MySQL C API實(shí)現(xiàn)。通過(guò)MySQLdb驅(qū)動(dòng)接口,Python程序就可以使用遵循Python數(shù)據(jù)庫(kù)API規(guī)范v2.0(PEP 249)的API來(lái)便捷地訪問(wèn)MySQL數(shù)據(jù)庫(kù)了。

遺憾的是MySQLdb只支持Python 2.x,不支持Python 3.x,并且已經(jīng)于2014年初停止更新維護(hù)了。不過(guò)慶幸的是mysqlclient撿起了接力棒,它派生于MySQLdb,修復(fù)了一些bug,支持Python 3.x,并保持持續(xù)更新維護(hù),目前最新版本為2.0.1。

注:雖然mysqlclient項(xiàng)目的PyPI包名為mysqlclient,但在Python編程調(diào)用模塊時(shí)仍然使用import MySQLdb,而不是import mysqlclient。這么做的原可能是mysqlclient作者希望mysqlclient項(xiàng)目最終能重新合并回MySQLdb項(xiàng)目吧。
以下是新舊對(duì)比表:

# 2. MySQLdb 安裝
2.1 MySQL下載安裝

一、MySQL下載
可從MySQL官方下載網(wǎng)址上找到安裝包。

注:這里選擇64位Windows平臺(tái)對(duì)應(yīng)的最新MySQL Community版本安裝文件:mysql-installer-community-8.0.21.0.msi。
二、MySQL安裝
執(zhí)行mysql-installer-community-8.0.21.0.msi安裝文件,根據(jù)提示完成MySQL安裝。
三、MySQL賬戶權(quán)限設(shè)置

2.2 Python下載安裝

一、Python下載
可從Python官方下載網(wǎng)址上找到安裝包。

注:這里選擇64位Windows平臺(tái)對(duì)應(yīng)的最新版本的Python安裝文件:python-3.8.5-amd64.exe。
二、Python安裝
執(zhí)行python-3.8.5-amd64.exe安裝文件,根據(jù)提示完成Python安裝。
注:在Windows上安裝Python時(shí),請(qǐng)務(wù)必在安裝過(guò)程中啟用【將python.exe添加到Path】 。
2.3 MySQLdb下載安裝

MySQLdb可以通過(guò)pip命令來(lái)完成下載安裝。(注:本文實(shí)際編程時(shí)涉及的MySQLdb均指mysqlclient)

注:在Windows上,mysqlclient的默認(rèn)安裝位置為:{python安裝路徑}Libsite-packages。如本機(jī)Python安裝在C:DevelopPython目錄下,則mysqlclient安裝在C:DevelopPythonLibsite-packages目錄下。
可通過(guò)如下方式對(duì)安裝進(jìn)行驗(yàn)證:

3. MySQLdb 示例代碼
Python通過(guò)MySQLdb驅(qū)動(dòng)接口訪問(wèn)操作MySQL的一般流程為:(1) 建立連接;(2) 獲取游標(biāo);(3) 執(zhí)行SQL;(4) 提交事務(wù); (5) 釋放資源。
下面針對(duì)訪問(wèn)MySQL數(shù)據(jù)庫(kù)常見(jiàn)的操作(如:連接數(shù)據(jù)庫(kù)、創(chuàng)建數(shù)據(jù)庫(kù)、刪除數(shù)據(jù)庫(kù)、創(chuàng)建數(shù)據(jù)表、刪除數(shù)據(jù)表、插入數(shù)據(jù)記錄、刪除數(shù)據(jù)記錄、修改數(shù)據(jù)記錄、查詢數(shù)據(jù)記錄等)分別給出一個(gè)較為完整的入門示例(含詳細(xì)代碼注釋)。
3.1 創(chuàng)建數(shù)據(jù)庫(kù)連接示例

說(shuō)明:MySQLdb.connect()構(gòu)造函數(shù)創(chuàng)建到MySQL服務(wù)器的連接并返回一個(gè) MySQLConnection對(duì)象。
3.2 創(chuàng)建數(shù)據(jù)庫(kù)示例

幾個(gè)關(guān)鍵方法說(shuō)明:
(1) cursor() 方法:獲得MySQL的操作游標(biāo),利用游標(biāo)來(lái)執(zhí)行SQL語(yǔ)句。
(2) execute() 方法:將字符串內(nèi)容當(dāng)做命令來(lái)執(zhí)行,作用是動(dòng)態(tài)創(chuàng)建和執(zhí)行SQL語(yǔ)句。
(3) commit() 方法:真正將SQL語(yǔ)句提交到數(shù)據(jù)庫(kù)執(zhí)行。對(duì)于數(shù)據(jù)的增刪改查操作,都需要調(diào)用該方法才能生效。
(4) rollback() 方法:如果執(zhí)行失敗,調(diào)用該方法執(zhí)行數(shù)據(jù)回滾,相當(dāng)于什么都沒(méi)發(fā)生過(guò)。
3.3 刪除數(shù)據(jù)庫(kù)示例

3.4 創(chuàng)建數(shù)據(jù)表示例

3.5 刪除數(shù)據(jù)表示例

3.6 插入數(shù)據(jù)記錄示例

3.7 批量插入數(shù)據(jù)記錄示例

3.8 刪除數(shù)據(jù)記錄示例

3.9 修改數(shù)據(jù)記錄示例

3.10 查詢數(shù)據(jù)記錄示例

根據(jù)讀取數(shù)據(jù)的多少,應(yīng)采用不同的方法:
(1) 如果讀取全部數(shù)據(jù),使用fetchall() 方法。
(2) 如果讀取多條數(shù)據(jù),使用fetchmany(n) 方法。
(3) 如果讀取一條數(shù)據(jù),使用fetchone()方法。
結(jié)束語(yǔ)
通過(guò)上面的介紹,相信感興趣的朋友們已經(jīng)對(duì)Python通過(guò)MySQLdb驅(qū)動(dòng)接口來(lái)訪問(wèn)操作MySQL數(shù)據(jù)庫(kù)有了一個(gè)基本的入門了解了。
不知您有沒(méi)有發(fā)現(xiàn),PyMySQL示例代碼跟上一篇介紹的PyMySQL示例代碼差不多,將之前示例代碼中所有的“pymysql”替換為"MySQLdb"即可。為什么呢?原因就在于它們都遵循Python數(shù)據(jù)庫(kù)API規(guī)范v2.0(PEP 249)。
本系列下一篇文章將針對(duì) “Python通過(guò)SQLAlchemy-SQL來(lái)訪問(wèn)操作MySQL數(shù)據(jù)庫(kù)” 進(jìn)行介紹,敬請(qǐng)關(guān)注后續(xù)文章!
本文為原創(chuàng),如果文章對(duì)您有所幫助,喜歡的話就點(diǎn)個(gè)贊加關(guān)注支持一下哈:)