欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Python操作MySQL數(shù)據(jù)庫的方法

 更新時間:2018年06月20日 09:16:44   作者:IT拾荒者  
pymsql是Python中操作MySQL的模塊,其使用方法和MySQLdb幾乎相同。接下來通過本文給大家介紹Python操作MySQL數(shù)據(jù)庫的方法,感興趣的朋友一起看看吧

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)建游標
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)])
# 提交,不然無法保存新建或者修改的數(shù)據(jù)
conn.commit()
# 關閉游標
cursor.close()
# 關閉連接
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、獲取查詢數(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ù)時按照順序進行,可以使用cursor.scroll(num,mode)來移動游標位置,如:

cursor.scroll(1,mode='relative') # 相對當前位置移動
cursor.scroll(2,mode='absolute') # 相對絕對位置移動

4、fetch數(shù)據(jù)類型

關于默認獲取的數(shù)據(jù)是元祖類型,如果想要或者字典類型的數(shù)據(jù),即:

import pymysql
conn = pymysql.connect(host='127.0.0.1', port=3306, user='root', passwd='123', db='t1')
# 游標設置為字典類型
cursor = conn.cursor(cursor=pymysql.cursors.DictCursor)
r = cursor.execute("call p1()")
result = cursor.fetchone()
conn.commit()
cursor.close()
conn.close()

數(shù)據(jù)庫補充

導出現(xiàn)有數(shù)據(jù)庫數(shù)據(jù):

mysqldump -u用戶名 -p密碼 數(shù)據(jù)庫名稱 >導出文件路徑           # 結構+數(shù)據(jù)

mysqldump -u用戶名 -p密碼 -d 數(shù)據(jù)庫名稱 >導出文件路徑       # 結構

導入現(xiàn)有數(shù)據(jù)庫數(shù)據(jù):

mysqldump -uroot -p密碼  數(shù)據(jù)庫名稱 < 文件路徑

MySQL中四種常用存儲引擎的介紹

(1):MyISAM存儲引擎:不支持事務、也不支持外鍵,優(yōu)勢是訪問速度快,對事務完整性沒有 要求或者以select,insert為主的應用基本上可以用這個引擎來創(chuàng)建表

支持3種不同的存儲格式,分別是:靜態(tài)表;動態(tài)表;壓縮表

靜態(tài)表:表中的字段都是非變長字段,這樣每個記錄都是固定長度的,優(yōu)點存儲非常迅速,容易緩存,出現(xiàn)故障容易恢復;缺點是占用的空間通常比動態(tài)表多(因為存儲時會按照列的寬度定義補足空格)ps:在取數(shù)據(jù)的時候,默認會把字段后面的空格去掉,如果不注意會把數(shù)據(jù)本身帶的空格也會忽略。

動態(tài)表:記錄不是固定長度的,這樣存儲的優(yōu)點是占用的空間相對較少;缺點:頻繁的更新、刪除數(shù)據(jù)容易產生碎片,需要定期執(zhí)行OPTIMIZE TABLE或者myisamchk-r命令來改善性能

壓縮表:因為每個記錄是被單獨壓縮的,所以只有非常小的訪問開支

(2)InnoDB存儲引擎*

該存儲引擎提供了具有提交、回滾和崩潰恢復能力的事務安全。但是對比MyISAM引擎,寫的處理效率會差一些,并且會占用更多的磁盤空間以保留數(shù)據(jù)和索引。
InnoDB存儲引擎的特點:支持自動增長列,支持外鍵約束

(3):MEMORY存儲引擎

Memory存儲引擎使用存在于內存中的內容來創(chuàng)建表。每個memory表只實際對應一個磁盤文件,格式是.frm。memory類型的表訪問非常的快,因為它的數(shù)據(jù)是放在內存中的,并且默認使用HASH索引,但是一旦服務關閉,表中的數(shù)據(jù)就會丟失掉。
MEMORY存儲引擎的表可以選擇使用BTREE索引或者HASH索引,兩種不同類型的索引有其不同的使用范圍

Hash索引優(yōu)點:

Hash 索引結構的特殊性,其檢索效率非常高,索引的檢索可以一次定位,不像B-Tree 索引需要從根節(jié)點到枝節(jié)點,最后才能訪問到頁節(jié)點這樣多次的IO訪問,所以 Hash 索引的查詢效率要遠高于 B-Tree 索引。
Hash索引缺點: 那么不精確查找呢,也很明顯,因為hash算法是基于等值計算的,所以對于“l(fā)ike”等范圍查找hash索引無效,不支持;

Memory類型的存儲引擎主要用于哪些內容變化不頻繁的代碼表,或者作為統(tǒng)計操作的中間結果表,便于高效地對中間結果進行分析并得到最終的統(tǒng)計結果,。對存儲引擎為memory的表進行更新操作要謹慎,因為數(shù)據(jù)并沒有實際寫入到磁盤中,所以一定要對下次重新啟動服務后如何獲得這些修改后的數(shù)據(jù)有所考慮。

(4)MERGE存儲引擎

Merge存儲引擎是一組MyISAM表的組合,這些MyISAM表必須結構完全相同,merge表本身并沒有數(shù)據(jù),對merge類型的表可以進行查詢,更新,刪除操作,這些操作實際上是對內部的MyISAM表進行的。

總結

以上所述是小編給大家介紹的Python操作MySQL數(shù)據(jù)庫的方法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!

相關文章

  • Python實現(xiàn)不一樣的猜數(shù)字游戲的示例代碼

    Python實現(xiàn)不一樣的猜數(shù)字游戲的示例代碼

    大家知道“猜數(shù)字”這個游戲嗎?顧名思義就是一個人想一個數(shù)字,另一個人猜。本文就來用Python實現(xiàn)一款不一樣的猜數(shù)字游戲,感興趣的可以了解一下
    2023-02-02
  • python實現(xiàn)批量轉換文件編碼(批轉換編碼示例)

    python實現(xiàn)批量轉換文件編碼(批轉換編碼示例)

    這篇文章主要介紹了python實現(xiàn)批量轉換文件編碼示例,指定文件編碼、目錄或擴展名即可進行轉換,大家參考使用吧
    2014-01-01
  • 穩(wěn)扎穩(wěn)打學Python之容器 可迭代對象 迭代器 生成器專題講解

    穩(wěn)扎穩(wěn)打學Python之容器 可迭代對象 迭代器 生成器專題講解

    在剛開始學Python的時候,是不是經(jīng)常會聽到大佬們在講容器、可迭代對象、迭代器、生成器、列表/集合/字典推導式等等眾多概念,其實這不是大佬們沒事就擱那扯專業(yè)術語來裝B,而是這些東西都得要明白的,光知道字符串、列表等基礎還是不夠的,尤其是在Python的數(shù)據(jù)結構方面
    2021-10-10
  • Windows下python3安裝tkinter的問題及解決方法

    Windows下python3安裝tkinter的問題及解決方法

    這篇文章主要介紹了Windows下python3安裝tkinter問題及解決方法,本文給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-01-01
  • Sanic框架應用部署方法詳解

    Sanic框架應用部署方法詳解

    這篇文章主要介紹了Sanic框架應用部署方法,結合實例形式分析了Sanic框架應用部署的具體流程、相關命令與使用技巧,并附帶說明了Gunicorn的配置方法,需要的朋友可以參考下
    2018-07-07
  • Flask配置四種方式

    Flask配置四種方式

    Flask提供了多種配置方式,可以根據(jù)不同的需求和場景進行選擇,包括配置類方式、配置文件方式、環(huán)境變量方式和實例文件方式,具有一定的參考價值,感興趣的可以了解一下
    2023-11-11
  • 在Django的模型和公用函數(shù)中使用惰性翻譯對象

    在Django的模型和公用函數(shù)中使用惰性翻譯對象

    這篇文章主要介紹了在Django的模型和公用函數(shù)中使用惰性翻譯對象,Django是豐富多彩的Python框架中人氣最高的一個,需要的朋友可以參考下
    2015-07-07
  • 基于python實現(xiàn)名片管理系統(tǒng)

    基于python實現(xiàn)名片管理系統(tǒng)

    這篇文章主要為大家詳細介紹了基于python實現(xiàn)名片管理系統(tǒng),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-11-11
  • 用Python實現(xiàn)控制電腦鼠標

    用Python實現(xiàn)控制電腦鼠標

    大家好,本篇文章主要講的是用Python實現(xiàn)控制電腦鼠標,感興趣的同學趕快來看一看吧,對你有幫助的話記得收藏一下
    2022-01-01
  • python實現(xiàn)kmp算法的實例代碼

    python實現(xiàn)kmp算法的實例代碼

    這篇文章主要介紹了python實現(xiàn)kmp算法的實例代碼,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-04-04

最新評論