日日操夜夜添-日日操影院-日日草夜夜操-日日干干-精品一区二区三区波多野结衣-精品一区二区三区高清免费不卡

公告:魔扣目錄網(wǎng)為廣大站長(zhǎng)提供免費(fèi)收錄網(wǎng)站服務(wù),提交前請(qǐng)做好本站友鏈:【 網(wǎng)站目錄:http://www.ylptlb.cn 】, 免友鏈快審服務(wù)(50元/站),

點(diǎn)擊這里在線咨詢客服
新站提交
  • 網(wǎng)站:51998
  • 待審:31
  • 小程序:12
  • 文章:1030137
  • 會(huì)員:747

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ù)了。

Python通過(guò)MySQLdb訪問(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。

Python通過(guò)MySQLdb訪問(wèn)操作MySQL數(shù)據(jù)庫(kù)

 

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

以下是新舊對(duì)比表:

Python通過(guò)MySQLdb訪問(wèn)操作MySQL數(shù)據(jù)庫(kù)

 

# 2. MySQLdb 安裝


2.1 MySQL下載安裝

Python通過(guò)MySQLdb訪問(wèn)操作MySQL數(shù)據(jù)庫(kù)

 

一、MySQL下載

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

Python通過(guò)MySQLdb訪問(wèn)操作MySQL數(shù)據(jù)庫(kù)

 

注:這里選擇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è)置

Python通過(guò)MySQLdb訪問(wèn)操作MySQL數(shù)據(jù)庫(kù)

 

2.2 Python下載安裝

Python通過(guò)MySQLdb訪問(wèn)操作MySQL數(shù)據(jù)庫(kù)

 

一、Python下載

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

Python通過(guò)MySQLdb訪問(wèn)操作MySQL數(shù)據(jù)庫(kù)

 

注:這里選擇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下載安裝

Python通過(guò)MySQLdb訪問(wèn)操作MySQL數(shù)據(jù)庫(kù)

 

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

Python通過(guò)MySQLdb訪問(wèn)操作MySQL數(shù)據(jù)庫(kù)

 

注:在Windows上,mysqlclient的默認(rèn)安裝位置為:{python安裝路徑}Libsite-packages。如本機(jī)Python安裝在C:DevelopPython目錄下,則mysqlclient安裝在C:DevelopPythonLibsite-packages目錄下。

可通過(guò)如下方式對(duì)安裝進(jìn)行驗(yàn)證:

Python通過(guò)MySQLdb訪問(wèn)操作MySQL數(shù)據(jù)庫(kù)

 

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ù)連接示例

Python通過(guò)MySQLdb訪問(wèn)操作MySQL數(shù)據(jù)庫(kù)

 

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

3.2 創(chuàng)建數(shù)據(jù)庫(kù)示例

Python通過(guò)MySQLdb訪問(wèn)操作MySQL數(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ù)示例

Python通過(guò)MySQLdb訪問(wèn)操作MySQL數(shù)據(jù)庫(kù)

 

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

Python通過(guò)MySQLdb訪問(wèn)操作MySQL數(shù)據(jù)庫(kù)

 

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

Python通過(guò)MySQLdb訪問(wèn)操作MySQL數(shù)據(jù)庫(kù)

 

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

Python通過(guò)MySQLdb訪問(wèn)操作MySQL數(shù)據(jù)庫(kù)

 

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

Python通過(guò)MySQLdb訪問(wèn)操作MySQL數(shù)據(jù)庫(kù)

 

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

Python通過(guò)MySQLdb訪問(wèn)操作MySQL數(shù)據(jù)庫(kù)

 

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

Python通過(guò)MySQLdb訪問(wèn)操作MySQL數(shù)據(jù)庫(kù)

 

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

Python通過(guò)MySQLdb訪問(wèn)操作MySQL數(shù)據(jù)庫(kù)

 

根據(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)注支持一下哈:)

分享到:
標(biāo)簽:MySQLdb
用戶無(wú)頭像

網(wǎng)友整理

注冊(cè)時(shí)間:

網(wǎng)站:5 個(gè)   小程序:0 個(gè)  文章:12 篇

  • 51998

    網(wǎng)站

  • 12

    小程序

  • 1030137

    文章

  • 747

    會(huì)員

趕快注冊(cè)賬號(hào),推廣您的網(wǎng)站吧!
最新入駐小程序

數(shù)獨(dú)大挑戰(zhàn)2018-06-03

數(shù)獨(dú)一種數(shù)學(xué)游戲,玩家需要根據(jù)9

答題星2018-06-03

您可以通過(guò)答題星輕松地創(chuàng)建試卷

全階人生考試2018-06-03

各種考試題,題庫(kù),初中,高中,大學(xué)四六

運(yùn)動(dòng)步數(shù)有氧達(dá)人2018-06-03

記錄運(yùn)動(dòng)步數(shù),積累氧氣值。還可偷

每日養(yǎng)生app2018-06-03

每日養(yǎng)生,天天健康

體育訓(xùn)練成績(jī)?cè)u(píng)定2018-06-03

通用課目體育訓(xùn)練成績(jī)?cè)u(píng)定