亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

帶你徹底搞懂python操作mysql數(shù)據(jù)庫(cursor游標(biāo)講解)

 更新時(shí)間:2020年01月06日 09:22:11   作者:Huang supreme  
這篇文章主要介紹了帶你徹底搞懂python操作mysql數(shù)據(jù)庫(cursor游標(biāo)講解),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

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 日志的方法

    本文給大家分享python 定時(shí)拆分備份 nginx 日志的方法,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧
    2020-04-04
  • python批量修改文件名的三種方法實(shí)例

    python批量修改文件名的三種方法實(shí)例

    同事最近有個(gè)需求,需要批量修改文件的名稱,這篇文章主要給大家介紹了關(guān)于python批量修改文件名的三種方法,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-05-05
  • python實(shí)現(xiàn)維吉尼亞加密法

    python實(shí)現(xiàn)維吉尼亞加密法

    這篇文章主要為大家詳細(xì)介紹了python實(shí)現(xiàn)維吉尼亞加密法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-03-03
  • 解決json.decoder.JSONDecodeError: Expecting value: line 1 column 1 (char 0)錯(cuò)誤

    解決json.decoder.JSONDecodeError: Expecting value:&n

    這篇文章主要介紹了解決json.decoder.JSONDecodeError: Expecting value: line 1 column 1 (char 0)錯(cuò)誤,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-04-04
  • Django框架會(huì)話技術(shù)實(shí)例分析【Cookie與Session】

    Django框架會(huì)話技術(shù)實(shí)例分析【Cookie與Session】

    這篇文章主要介紹了Django框架會(huì)話技術(shù),結(jié)合實(shí)例形式分析了Django框架Cookie與Session相關(guān)使用技巧與注意事項(xiàng),需要的朋友可以參考下
    2019-05-05
  • Python裝飾器原理與用法分析

    Python裝飾器原理與用法分析

    這篇文章主要介紹了Python裝飾器原理與用法,結(jié)合實(shí)例形式分析了Python裝飾器的概念、原理、使用方法及相關(guān)操作注意事項(xiàng),需要的朋友可以參考下
    2018-04-04
  • python-xpath獲取html文檔的部分內(nèi)容

    python-xpath獲取html文檔的部分內(nèi)容

    這篇文章主要介紹了python-xpath獲取html文檔的部分內(nèi)容,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-03-03
  • python 域名分析工具實(shí)現(xiàn)代碼

    python 域名分析工具實(shí)現(xiàn)代碼

    用python實(shí)現(xiàn)域名分析,數(shù)據(jù)來源金玉米
    2009-07-07
  • python實(shí)現(xiàn)微信小程序的多種支付方式

    python實(shí)現(xiàn)微信小程序的多種支付方式

    這篇文章主要為大家介紹了python實(shí)現(xiàn)微信小程序的多種支付方式的實(shí)現(xiàn)示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步早日升職加薪
    2022-04-04
  • Python?ORM數(shù)據(jù)庫框架Sqlalchemy的使用教程詳解

    Python?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

最新評論