帶你徹底搞懂python操作mysql數(shù)據(jù)庫(kù)(cursor游標(biāo)講解)
1、什么是游標(biāo)?

一張圖講述游標(biāo)的功能:

圖示說(shuō)明:

2、使用游標(biāo)的好處?
如果不使用游標(biāo)功能,直接使用select查詢,會(huì)一次性將結(jié)果集打印到屏幕上,你無(wú)法針對(duì)結(jié)果集做第二次編程。使用游標(biāo)功能后,我們可以將得到的結(jié)果先保存起來(lái),然后可以隨意進(jìn)行自己的編程,得到我們最終想要的結(jié)果集。
3、利用python連接數(shù)據(jù)庫(kù),經(jīng)常會(huì)使用游標(biāo)功能
1)以python連接mysql數(shù)據(jù)庫(kù)為例

2)使用游標(biāo)的操作步驟
- 首先,使用pymysql連接上mysql數(shù)據(jù)庫(kù),得到一個(gè)數(shù)據(jù)庫(kù)對(duì)象。
- 然后,我們必須要開(kāi)啟數(shù)據(jù)庫(kù)中的游標(biāo)功能,得到一個(gè)游標(biāo)對(duì)象。
- 接著,使用游標(biāo)對(duì)象中的execute()方法,去執(zhí)行某個(gè)SQL語(yǔ)句,系統(tǒng)會(huì)根據(jù)你的SQL語(yǔ)句,找到這些匹配行,給你存儲(chǔ)起來(lái),而不是一次性的打印到頻幕上。當(dāng)你什么時(shí)候需要這個(gè)結(jié)果中的數(shù)據(jù)的時(shí)候,你就去獲取它。
- 最后,就是獲取結(jié)果集中的數(shù)據(jù)了,這里有兩種方法獲取結(jié)果集中的數(shù)據(jù)。一個(gè)是fetchone(),該方法一次獲取一條記錄,每一條記錄是一個(gè)元組形式的數(shù)據(jù),每獲取一條記錄游標(biāo)會(huì)往前移動(dòng)一格,等待獲取下一條記錄;一個(gè)是fetchall()方法,能夠一次性的獲取所有的數(shù)據(jù),該方法返回的是一個(gè)元組列表。
- 當(dāng)完成所有操作后,記得斷開(kāi)數(shù)據(jù)庫(kù)的連接,釋放資源。
① 連接數(shù)據(jù)庫(kù),創(chuàng)建一個(gè)數(shù)據(jù)庫(kù)對(duì)象
db = pymysql.connect(host='localhost',user='root',db='huangwei',
password='123456',port=3306,charset='utf8')
注意:我們要操作的是huangwei這個(gè)數(shù)據(jù)庫(kù)中的表,因此在連接的時(shí)候使用db這個(gè)參數(shù)來(lái)指明要使用哪一個(gè)數(shù)據(jù)庫(kù);由于mysql數(shù)據(jù)庫(kù)就裝在本機(jī)上,因此可以寫(xiě)localhost,當(dāng)然你也可以寫(xiě)成主機(jī)名,或者主機(jī)ip;
② 開(kāi)啟游標(biāo)功能,創(chuàng)建游標(biāo)對(duì)象
# 這里使用的是數(shù)據(jù)庫(kù)對(duì)象db中的cursor()方法, cursor = db.cursor()
③ 使用execute()方法,執(zhí)行SQL語(yǔ)句
cursor.execute('select sname,ssex from student')
注意:當(dāng)開(kāi)啟游標(biāo)功能執(zhí)行這個(gè)SQL語(yǔ)句后,系統(tǒng)并不會(huì)將結(jié)果直接打印到頻幕上,而是將上述得到的結(jié)果,找個(gè)地方存儲(chǔ)起來(lái),提供一個(gè)游標(biāo)接口給我們,當(dāng)你需要獲取數(shù)據(jù) 的時(shí)候,就可以從中拿數(shù)據(jù)。
④ 使用fetchone()或fetchall()獲取數(shù)據(jù)
# 一次性獲取一條數(shù)據(jù) a = cursor.fetchone() # 一次性獲取所有數(shù)據(jù) a = cursor.fetchall()
注意:使用游標(biāo)獲取數(shù)據(jù),需要用一個(gè)變量將結(jié)果存儲(chǔ)起來(lái),才能被我們拿來(lái)做二次使用,這里在下面的案例中會(huì)體現(xiàn)出來(lái)。
⑤ 斷開(kāi)數(shù)據(jù)庫(kù),釋放資源
db.close()
3)案例講解
需求:以操做huangwei數(shù)據(jù)庫(kù)中的student表為例 。完成【篩選出女生,同時(shí)將sname以這種形式輸出“我叫周梅,我是一個(gè)學(xué)生!”】這個(gè)需求。
① student表

② 使用fetchone()方法,獲取SQL查詢結(jié)果集中的數(shù)據(jù)
db = pymysql.connect(host='localhost',user='root',db='huangwei',
password='123456',port=3306,charset='utf8')
cursor = db.cursor()
cursor.execute('select count(*) from student')
aa = cursor.fetchone()
print(aa)
# 注意這一句一定是在循環(huán)之外,不能放到循環(huán)里面。想想這是為什么?
cursor.execute('select sname,ssex from student')
for i in range(aa[0]):
a,b = cursor.fetchone()
if b == "女":
a = "我叫{},我是一個(gè)學(xué)生!".format(a)
print(a)
db.close()
結(jié)果如下:

③ 使用fetchall()方法,獲取SQL查詢結(jié)果集中的數(shù)據(jù)
db = pymysql.connect(host='localhost',user='root',db='huangwei',
password='123456',port=3306,charset='utf8')
cursor = db.cursor()
cursor.execute('select sname,ssex from student')
aa = cursor.fetchall()
# print(aa)
for a,b in aa:
if b == "女":
a = "我叫{},我是一個(gè)學(xué)生!".format(a)
print(a)
db.close()
結(jié)果如下:

④ 結(jié)果分析
通過(guò)上述操作可以發(fā)現(xiàn),這種游標(biāo)功能可以幫助我們對(duì)SQL語(yǔ)句得到的結(jié)果集,進(jìn)行二次開(kāi)發(fā),然后通過(guò)靈活的python語(yǔ)法,得到任何我們最終想要的結(jié)果集。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
對(duì)Django中內(nèi)置的User模型實(shí)例詳解
今天小編就為大家分享一篇對(duì)Django中內(nèi)置的User模型實(shí)例詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-08-08
python 根據(jù)csv表頭、列號(hào)讀取數(shù)據(jù)的實(shí)現(xiàn)
這篇文章主要介紹了python 根據(jù)csv表頭、列號(hào)讀取數(shù)據(jù)的實(shí)現(xiàn)方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-05-05
Python3.5內(nèi)置模塊之random模塊用法實(shí)例分析
這篇文章主要介紹了Python3.5內(nèi)置模塊之random模塊用法,結(jié)合實(shí)例形式分析了Python3.5 random模塊生成隨機(jī)數(shù)與隨機(jī)字符串相關(guān)操作技巧,需要的朋友可以參考下2019-04-04
在Ubuntu中安裝并配置Pycharm教程的實(shí)現(xiàn)方法
這篇文章主要介紹了在Ubuntu中安裝并配置Pycharm教程的實(shí)現(xiàn)方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-01-01
Python疊加兩幅柵格圖像的實(shí)現(xiàn)方法
今天小編就為大家分享一篇Python疊加兩幅柵格圖像的實(shí)現(xiàn)方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-07-07
SpringBoot調(diào)用python接口的實(shí)現(xiàn)步驟
本文主要介紹如何利用Springboot框架調(diào)用python腳本,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-12-12
Pycharm2020最新激活碼|永久激活(附最新激活碼和插件的詳細(xì)教程)
這篇文章主要介紹了Pycharm2020最新激活碼|永久激活(附最新激活碼和插件的詳細(xì)教程),本文通過(guò)圖文并茂的形式給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-09-09

