Python操作MySQL數(shù)據(jù)庫(kù)的方法
pymsql
pymsql是Python中操作MySQL的模塊,其使用方法和MySQLdb幾乎相同。
下載安裝
pip3 install pymysql
使用操作
1、執(zhí)行SQL
import pymysql # 創(chuàng)建連接 conn = pymysql.connect(host='127.0.0.1', port=3306, user='root', passwd='123', db='t1') # 創(chuàng)建游標(biāo) cursor = conn.cursor() # 執(zhí)行SQL,并返回收影響行數(shù) effect_row = cursor.execute("update hosts set host = '1.1.1.2'") # 執(zhí)行SQL,并返回受影響行數(shù) #effect_row = cursor.execute("update hosts set host = '1.1.1.2' where nid > %s", (1,)) # 執(zhí)行SQL,并返回受影響行數(shù) #effect_row = cursor.executemany("insert into hosts(host,color_id)values(%s,%s)", [("1.1.1.11",1),("1.1.1.11",2)]) # 提交,不然無(wú)法保存新建或者修改的數(shù)據(jù) conn.commit() # 關(guān)閉游標(biāo) cursor.close() # 關(guān)閉連接 conn.close()
2、獲取新創(chuàng)建數(shù)據(jù)自增ID
import pymysql conn = pymysql.connect(host='127.0.0.1', port=3306, user='root', passwd='123', db='t1') cursor = conn.cursor() cursor.executemany("insert into hosts(host,color_id)values(%s,%s)", [("1.1.1.11",1),("1.1.1.11",2)]) conn.commit() cursor.close() conn.close() # 獲取最新自增ID new_id = cursor.lastrowid
3、獲取查詢(xún)數(shù)據(jù)
import pymysql conn = pymysql.connect(host='127.0.0.1', port=3306, user='root', passwd='123', db='t1') cursor = conn.cursor() cursor.execute("select * from hosts") # 獲取第一行數(shù)據(jù) row_1 = cursor.fetchone() # 獲取前n行數(shù)據(jù) # row_2 = cursor.fetchmany(3) # 獲取所有數(shù)據(jù) # row_3 = cursor.fetchall() conn.commit() cursor.close() conn.close()
注:在fetch數(shù)據(jù)時(shí)按照順序進(jìn)行,可以使用cursor.scroll(num,mode)來(lái)移動(dòng)游標(biāo)位置,如:
cursor.scroll(1,mode='relative') # 相對(duì)當(dāng)前位置移動(dòng) cursor.scroll(2,mode='absolute') # 相對(duì)絕對(duì)位置移動(dòng)
4、fetch數(shù)據(jù)類(lèi)型
關(guān)于默認(rèn)獲取的數(shù)據(jù)是元祖類(lèi)型,如果想要或者字典類(lèi)型的數(shù)據(jù),即:
import pymysql conn = pymysql.connect(host='127.0.0.1', port=3306, user='root', passwd='123', db='t1') # 游標(biāo)設(shè)置為字典類(lèi)型 cursor = conn.cursor(cursor=pymysql.cursors.DictCursor) r = cursor.execute("call p1()") result = cursor.fetchone() conn.commit() cursor.close() conn.close()
數(shù)據(jù)庫(kù)補(bǔ)充
導(dǎo)出現(xiàn)有數(shù)據(jù)庫(kù)數(shù)據(jù):
mysqldump -u用戶名 -p密碼 數(shù)據(jù)庫(kù)名稱(chēng) >導(dǎo)出文件路徑 # 結(jié)構(gòu)+數(shù)據(jù)
mysqldump -u用戶名 -p密碼 -d 數(shù)據(jù)庫(kù)名稱(chēng) >導(dǎo)出文件路徑 # 結(jié)構(gòu)
導(dǎo)入現(xiàn)有數(shù)據(jù)庫(kù)數(shù)據(jù):
mysqldump -uroot -p密碼 數(shù)據(jù)庫(kù)名稱(chēng) < 文件路徑
MySQL中四種常用存儲(chǔ)引擎的介紹
(1):MyISAM存儲(chǔ)引擎:不支持事務(wù)、也不支持外鍵,優(yōu)勢(shì)是訪問(wèn)速度快,對(duì)事務(wù)完整性沒(méi)有 要求或者以select,insert為主的應(yīng)用基本上可以用這個(gè)引擎來(lái)創(chuàng)建表
支持3種不同的存儲(chǔ)格式,分別是:靜態(tài)表;動(dòng)態(tài)表;壓縮表
靜態(tài)表:表中的字段都是非變長(zhǎng)字段,這樣每個(gè)記錄都是固定長(zhǎng)度的,優(yōu)點(diǎn)存儲(chǔ)非常迅速,容易緩存,出現(xiàn)故障容易恢復(fù);缺點(diǎn)是占用的空間通常比動(dòng)態(tài)表多(因?yàn)榇鎯?chǔ)時(shí)會(huì)按照列的寬度定義補(bǔ)足空格)ps:在取數(shù)據(jù)的時(shí)候,默認(rèn)會(huì)把字段后面的空格去掉,如果不注意會(huì)把數(shù)據(jù)本身帶的空格也會(huì)忽略。
動(dòng)態(tài)表:記錄不是固定長(zhǎng)度的,這樣存儲(chǔ)的優(yōu)點(diǎn)是占用的空間相對(duì)較少;缺點(diǎn):頻繁的更新、刪除數(shù)據(jù)容易產(chǎn)生碎片,需要定期執(zhí)行OPTIMIZE TABLE或者myisamchk-r命令來(lái)改善性能
壓縮表:因?yàn)槊總€(gè)記錄是被單獨(dú)壓縮的,所以只有非常小的訪問(wèn)開(kāi)支
(2)InnoDB存儲(chǔ)引擎*
該存儲(chǔ)引擎提供了具有提交、回滾和崩潰恢復(fù)能力的事務(wù)安全。但是對(duì)比MyISAM引擎,寫(xiě)的處理效率會(huì)差一些,并且會(huì)占用更多的磁盤(pán)空間以保留數(shù)據(jù)和索引。
InnoDB存儲(chǔ)引擎的特點(diǎn):支持自動(dòng)增長(zhǎng)列,支持外鍵約束
(3):MEMORY存儲(chǔ)引擎
Memory存儲(chǔ)引擎使用存在于內(nèi)存中的內(nèi)容來(lái)創(chuàng)建表。每個(gè)memory表只實(shí)際對(duì)應(yīng)一個(gè)磁盤(pán)文件,格式是.frm。memory類(lèi)型的表訪問(wèn)非常的快,因?yàn)樗臄?shù)據(jù)是放在內(nèi)存中的,并且默認(rèn)使用HASH索引,但是一旦服務(wù)關(guān)閉,表中的數(shù)據(jù)就會(huì)丟失掉。
MEMORY存儲(chǔ)引擎的表可以選擇使用BTREE索引或者HASH索引,兩種不同類(lèi)型的索引有其不同的使用范圍
Hash索引優(yōu)點(diǎn):
Hash 索引結(jié)構(gòu)的特殊性,其檢索效率非常高,索引的檢索可以一次定位,不像B-Tree 索引需要從根節(jié)點(diǎn)到枝節(jié)點(diǎn),最后才能訪問(wèn)到頁(yè)節(jié)點(diǎn)這樣多次的IO訪問(wèn),所以 Hash 索引的查詢(xún)效率要遠(yuǎn)高于 B-Tree 索引。
Hash索引缺點(diǎn): 那么不精確查找呢,也很明顯,因?yàn)閔ash算法是基于等值計(jì)算的,所以對(duì)于“l(fā)ike”等范圍查找hash索引無(wú)效,不支持;
Memory類(lèi)型的存儲(chǔ)引擎主要用于哪些內(nèi)容變化不頻繁的代碼表,或者作為統(tǒng)計(jì)操作的中間結(jié)果表,便于高效地對(duì)中間結(jié)果進(jìn)行分析并得到最終的統(tǒng)計(jì)結(jié)果,。對(duì)存儲(chǔ)引擎為memory的表進(jìn)行更新操作要謹(jǐn)慎,因?yàn)閿?shù)據(jù)并沒(méi)有實(shí)際寫(xiě)入到磁盤(pán)中,所以一定要對(duì)下次重新啟動(dòng)服務(wù)后如何獲得這些修改后的數(shù)據(jù)有所考慮。
(4)MERGE存儲(chǔ)引擎
Merge存儲(chǔ)引擎是一組MyISAM表的組合,這些MyISAM表必須結(jié)構(gòu)完全相同,merge表本身并沒(méi)有數(shù)據(jù),對(duì)merge類(lèi)型的表可以進(jìn)行查詢(xún),更新,刪除操作,這些操作實(shí)際上是對(duì)內(nèi)部的MyISAM表進(jìn)行的。
總結(jié)
以上所述是小編給大家介紹的Python操作MySQL數(shù)據(jù)庫(kù)的方法,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
- 詳解使用pymysql在python中對(duì)mysql的增刪改查操作(綜合)
- python使用pymysql實(shí)現(xiàn)操作mysql
- Python中操作mysql的pymysql模塊詳解
- Python的SQLalchemy模塊連接與操作MySQL的基礎(chǔ)示例
- Python2.7簡(jiǎn)單連接與操作MySQL的方法
- Python操作MySQL數(shù)據(jù)庫(kù)9個(gè)實(shí)用實(shí)例
- 使用Python操作MySQL的一些基本方法
- 在Python程序中操作MySQL的基本方法
- Python操作MySQL簡(jiǎn)單實(shí)現(xiàn)方法
- Python讀取ini文件、操作mysql、發(fā)送郵件實(shí)例
相關(guān)文章
Python實(shí)現(xiàn)不一樣的猜數(shù)字游戲的示例代碼
大家知道“猜數(shù)字”這個(gè)游戲嗎?顧名思義就是一個(gè)人想一個(gè)數(shù)字,另一個(gè)人猜。本文就來(lái)用Python實(shí)現(xiàn)一款不一樣的猜數(shù)字游戲,感興趣的可以了解一下2023-02-02python實(shí)現(xiàn)批量轉(zhuǎn)換文件編碼(批轉(zhuǎn)換編碼示例)
這篇文章主要介紹了python實(shí)現(xiàn)批量轉(zhuǎn)換文件編碼示例,指定文件編碼、目錄或擴(kuò)展名即可進(jìn)行轉(zhuǎn)換,大家參考使用吧2014-01-01穩(wěn)扎穩(wěn)打?qū)WPython之容器 可迭代對(duì)象 迭代器 生成器專(zhuān)題講解
在剛開(kāi)始學(xué)Python的時(shí)候,是不是經(jīng)常會(huì)聽(tīng)到大佬們?cè)谥v容器、可迭代對(duì)象、迭代器、生成器、列表/集合/字典推導(dǎo)式等等眾多概念,其實(shí)這不是大佬們沒(méi)事就擱那扯專(zhuān)業(yè)術(shù)語(yǔ)來(lái)裝B,而是這些東西都得要明白的,光知道字符串、列表等基礎(chǔ)還是不夠的,尤其是在Python的數(shù)據(jù)結(jié)構(gòu)方面2021-10-10Windows下python3安裝tkinter的問(wèn)題及解決方法
這篇文章主要介紹了Windows下python3安裝tkinter問(wèn)題及解決方法,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-01-01在Django的模型和公用函數(shù)中使用惰性翻譯對(duì)象
這篇文章主要介紹了在Django的模型和公用函數(shù)中使用惰性翻譯對(duì)象,Django是豐富多彩的Python框架中人氣最高的一個(gè),需要的朋友可以參考下2015-07-07基于python實(shí)現(xiàn)名片管理系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了基于python實(shí)現(xiàn)名片管理系統(tǒng),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-11-11用Python實(shí)現(xiàn)控制電腦鼠標(biāo)
大家好,本篇文章主要講的是用Python實(shí)現(xiàn)控制電腦鼠標(biāo),感興趣的同學(xué)趕快來(lái)看一看吧,對(duì)你有幫助的話記得收藏一下2022-01-01python實(shí)現(xiàn)kmp算法的實(shí)例代碼
這篇文章主要介紹了python實(shí)現(xiàn)kmp算法的實(shí)例代碼,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-04-04