帶你徹底搞懂python操作mysql數(shù)據(jù)庫(cursor游標(biāo)講解)
1、什么是游標(biāo)?
一張圖講述游標(biāo)的功能:
圖示說明:
2、使用游標(biāo)的好處?
如果不使用游標(biāo)功能,直接使用select查詢,會(huì)一次性將結(jié)果集打印到屏幕上,你無法針對結(jié)果集做第二次編程。使用游標(biāo)功能后,我們可以將得到的結(jié)果先保存起來,然后可以隨意進(jìn)行自己的編程,得到我們最終想要的結(jié)果集。
3、利用python連接數(shù)據(jù)庫,經(jīng)常會(huì)使用游標(biāo)功能
1)以python連接mysql數(shù)據(jù)庫為例
2)使用游標(biāo)的操作步驟
- 首先,使用pymysql連接上mysql數(shù)據(jù)庫,得到一個(gè)數(shù)據(jù)庫對象。
- 然后,我們必須要開啟數(shù)據(jù)庫中的游標(biāo)功能,得到一個(gè)游標(biāo)對象。
- 接著,使用游標(biāo)對象中的execute()方法,去執(zhí)行某個(gè)SQL語句,系統(tǒng)會(huì)根據(jù)你的SQL語句,找到這些匹配行,給你存儲(chǔ)起來,而不是一次性的打印到頻幕上。當(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)完成所有操作后,記得斷開數(shù)據(jù)庫的連接,釋放資源。
① 連接數(shù)據(jù)庫,創(chuàng)建一個(gè)數(shù)據(jù)庫對象
db = pymysql.connect(host='localhost',user='root',db='huangwei', password='123456',port=3306,charset='utf8')
注意:我們要操作的是huangwei這個(gè)數(shù)據(jù)庫中的表,因此在連接的時(shí)候使用db這個(gè)參數(shù)來指明要使用哪一個(gè)數(shù)據(jù)庫;由于mysql數(shù)據(jù)庫就裝在本機(jī)上,因此可以寫localhost,當(dāng)然你也可以寫成主機(jī)名,或者主機(jī)ip;
② 開啟游標(biāo)功能,創(chuàng)建游標(biāo)對象
# 這里使用的是數(shù)據(jù)庫對象db中的cursor()方法, cursor = db.cursor()
③ 使用execute()方法,執(zhí)行SQL語句
cursor.execute('select sname,ssex from student')
注意:當(dāng)開啟游標(biāo)功能執(zhí)行這個(gè)SQL語句后,系統(tǒng)并不會(huì)將結(jié)果直接打印到頻幕上,而是將上述得到的結(jié)果,找個(gè)地方存儲(chǔ)起來,提供一個(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ǔ)起來,才能被我們拿來做二次使用,這里在下面的案例中會(huì)體現(xiàn)出來。
⑤ 斷開數(shù)據(jù)庫,釋放資源
db.close()
3)案例講解
需求:以操做huangwei數(shù)據(jù)庫中的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é)果分析
通過上述操作可以發(fā)現(xiàn),這種游標(biāo)功能可以幫助我們對SQL語句得到的結(jié)果集,進(jìn)行二次開發(fā),然后通過靈活的python語法,得到任何我們最終想要的結(jié)果集。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
淺析python 定時(shí)拆分備份 nginx 日志的方法
本文給大家分享python 定時(shí)拆分備份 nginx 日志的方法,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧2020-04-04解決json.decoder.JSONDecodeError: Expecting value:&n
這篇文章主要介紹了解決json.decoder.JSONDecodeError: Expecting value: line 1 column 1 (char 0)錯(cuò)誤,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-04-04Django框架會(huì)話技術(shù)實(shí)例分析【Cookie與Session】
這篇文章主要介紹了Django框架會(huì)話技術(shù),結(jié)合實(shí)例形式分析了Django框架Cookie與Session相關(guān)使用技巧與注意事項(xiàng),需要的朋友可以參考下2019-05-05python-xpath獲取html文檔的部分內(nèi)容
這篇文章主要介紹了python-xpath獲取html文檔的部分內(nèi)容,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-03-03python實(shí)現(xiàn)微信小程序的多種支付方式
這篇文章主要為大家介紹了python實(shí)現(xiàn)微信小程序的多種支付方式的實(shí)現(xiàn)示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步早日升職加薪2022-04-04Python?ORM數(shù)據(jù)庫框架Sqlalchemy的使用教程詳解
對象關(guān)系映射(Object?Relational?Mapping,簡稱ORM)模式是一種為了解決面向?qū)ο笈c關(guān)系數(shù)據(jù)庫存在的互不匹配的現(xiàn)象的技術(shù)。本文主要介紹了其使用的相關(guān)資料,感興趣的小伙伴可以學(xué)習(xí)一下2022-10-10