日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

mysql打印语句_最全总结 | 聊聊 Python 数据处理全家桶(Mysql 篇)

發(fā)布時(shí)間:2025/3/19 数据库 30 豆豆
生活随笔 收集整理的這篇文章主要介紹了 mysql打印语句_最全总结 | 聊聊 Python 数据处理全家桶(Mysql 篇) 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

點(diǎn)擊上方“AirPython”,選擇“加為星標(biāo)”

第一時(shí)間關(guān)注 Python 技術(shù)干貨!

1. 前言

在爬蟲、自動(dòng)化、數(shù)據(jù)分析、軟件測試、Web 等日常操作中,除?JSON、YAML、XML 外,還有一些數(shù)據(jù)經(jīng)常會(huì)用到,比如:Mysql、Sqlite、Redis、MongoDB、Memchache 等?

一般情況下,我們都會(huì)使用特定的客戶端或命令行工具去操作;但是如果涉及到工程項(xiàng)目,將這部分?jǐn)?shù)據(jù)操作集成到代碼中使用才是王道

接下來,我將分幾篇文章,和大家一起聊聊 Python 操作這些數(shù)據(jù)的 最優(yōu) 方案

本篇從使用最為廣泛的關(guān)系型數(shù)據(jù)庫 - Mysql 開始講起

2. 準(zhǔn)備

首先,我們通過 Mysql 客戶端或命令行創(chuàng)建一個(gè)數(shù)據(jù)庫?xh

然后,在這個(gè)數(shù)據(jù)庫下建一張簡單的表?people

為了便于演示,這里只創(chuàng)建了三個(gè)字段:id、name、age,其中 id 為主鍵

Python 操作 Mysql 主要包含下面 3 種方式:

  • Python-MySql

  • PyMysql

  • SQLAlchemy

其中,

Python-MySql 由 C 語法打造,接口精煉,性能最棒;但是由于環(huán)境依賴多,安裝復(fù)雜,已停止更新,僅支持 Python2

PyMysql?為替代 Python-Mysql 而生,純 Python?語言編寫的 Mysql 操作客戶端,安裝方便,支持 Python3

SQLAlchemy 是一個(gè)非常強(qiáng)大的 ORM 框架,不提供底層的數(shù)據(jù)庫操作,主要是通過定義模型對(duì)應(yīng)數(shù)據(jù)表結(jié)構(gòu),在 Python Web 編程領(lǐng)域應(yīng)用廣泛

由于 Python-MySql? 不支持 Python3,所以本文只談后 2 種操作方式

3. PyMysql

首先,使用 pip?安裝依賴

#?安裝依賴

連接數(shù)據(jù)庫,獲取數(shù)據(jù)庫連接對(duì)象及游標(biāo)對(duì)象

使用?pymysql 中的 connect() 方法,傳入數(shù)據(jù)庫的 HOST 地址、端口號(hào)、用戶名、密碼、待操作數(shù)據(jù)庫的名稱,即可以獲取?數(shù)據(jù)庫的連接對(duì)象

然后,再通過數(shù)據(jù)庫連接對(duì)象,獲取執(zhí)行數(shù)據(jù)庫具體操作的?游標(biāo)對(duì)象

import?pymysql

#?數(shù)據(jù)庫連接
self.db?=?pymysql.connect(host='localhost',
??????????????????????????port=3306,
??????????????????????????user='root',
??????????????????????????password='**',
??????????????????????????database='xh')

#?獲取游標(biāo)
self.cursor?=?self.db.cursor()

接著,我們來實(shí)現(xiàn)增刪改查操作

1、新增

新增包含新增單條數(shù)據(jù)和多條數(shù)據(jù)

對(duì)于單條數(shù)據(jù)的插入,只需要編寫一條插入的 SQL 語句,然后作為參數(shù)執(zhí)行上面游標(biāo)對(duì)象的?execute(sql) 方法,最后使用數(shù)據(jù)庫連接對(duì)象的 commit() 方法將數(shù)據(jù)提交到數(shù)據(jù)庫中

#?插入一條數(shù)據(jù)

使用執(zhí)行游標(biāo)對(duì)象的?executemany() 方法,傳入插入的 SQL 語句及?位置變量列表,可以實(shí)現(xiàn)一次插入多條數(shù)據(jù)

#?插入多條數(shù)據(jù)SQL,name和age是變量,對(duì)應(yīng)列表

需要注意的是,PyMysql 會(huì)將 SQL 語句中的所有字段當(dāng)做字符串進(jìn)行處理,所以這里的 age 字段在 SQL 中被當(dāng)做字符串處理

2、查詢

查詢分為三步,分別是:

  • 通過游標(biāo)對(duì)象執(zhí)行具體的 SQL 語句

  • 通過游標(biāo)對(duì)象,獲取到元組數(shù)據(jù)

  • 遍歷元組數(shù)據(jù),查看結(jié)果

比如:查看數(shù)據(jù)表中所有的記錄

#?查詢所有記錄

如果需要按條件查詢某一條記錄,只需要修改 SQL 語句即可實(shí)現(xiàn)

#?按id查詢

3、更新

和 新增操作 類似,更新操作也是通過游標(biāo)對(duì)象去執(zhí)行更新的 SQL?語句,最后利用數(shù)據(jù)庫連接對(duì)象將數(shù)據(jù)真實(shí)更新到數(shù)據(jù)庫中

#?更新(通過id去更新)

4、刪除

刪除操作同查詢、新增操作類似,只需要變更 SQL 語句即可

#?刪除(通過id去刪除數(shù)據(jù))

最后,我們需要將游標(biāo)對(duì)象和數(shù)據(jù)庫連接對(duì)象資源釋放掉

def?teardown(self):

4.?SQLAlchemy

首先,使用 SQLAlchemy 操作 Mysql 數(shù)據(jù)庫同樣先需要安裝依賴庫

#?安裝依賴包

通過 SQLAlchemy?的內(nèi)置方法?declarative_base()?創(chuàng)建一個(gè)基礎(chǔ)類 Base

然后,自定義一個(gè) Base 類的子類,內(nèi)部定義靜態(tài)變量,和上面數(shù)據(jù)表 people 中的字段一一對(duì)應(yīng)

from?sqlalchemy?

接著,通過數(shù)據(jù)庫名、用戶名、密碼及 Host 組裝一個(gè)數(shù)據(jù)庫連接地址,作為參數(shù)傳入到?SQLAlchemy 的?create_engine()?方法中,以創(chuàng)建一個(gè)數(shù)據(jù)庫引擎實(shí)例對(duì)象

#?創(chuàng)建數(shù)據(jù)庫的引擎實(shí)例對(duì)象

最后,通過數(shù)據(jù)庫引擎在數(shù)據(jù)庫中創(chuàng)建表結(jié)構(gòu),并實(shí)例化一個(gè)?會(huì)話對(duì)象

需要注意的是,create_all() 方法中的?checkfirst 參數(shù)如果傳入 True,則會(huì)判斷數(shù)據(jù)表是否存在,如果表存在,則不會(huì)重新創(chuàng)建

#?創(chuàng)建表結(jié)構(gòu)

這樣所有的準(zhǔn)備工作已經(jīng)完成,接下來可以進(jìn)行增刪改查操作了

1、新增

新增操作同樣包含插入一條記錄和多條記錄,分別對(duì)應(yīng)會(huì)話對(duì)象的 add()、add_all() 方法

對(duì)于一條記錄的新增操作,只需要實(shí)例化一個(gè)?People 對(duì)象,執(zhí)行上面的會(huì)話對(duì)象的 add(instance) 和?commit()?兩個(gè)方法,即可以將數(shù)據(jù)插入到數(shù)據(jù)表中

def?add_item(self):

如果需要一次插入多條數(shù)據(jù),只需要調(diào)用 add_all(列表數(shù)據(jù))?即可

def?add_items(self):

2、查詢

查詢數(shù)據(jù)表的操作對(duì)應(yīng)會(huì)話對(duì)象的 query(可變參數(shù))

方法中的參數(shù)指定要查詢的字段值,還可以通過?all()、first()?級(jí)聯(lián)方法限制要查詢的數(shù)據(jù)

def?query(self):

當(dāng)然,也可以利用?filter_by(條件),按條件進(jìn)行過濾

#?條件查詢

3、更新

更新操作一般做法是:

  • query 查詢出待更新的對(duì)象

  • 直接更新對(duì)象中的數(shù)據(jù)

  • 使用會(huì)話對(duì)象提交修改,完成更新操作

def?update1(self,?id):

需要指出的是,這里可以使用 update() 方法進(jìn)行簡寫

def?update2(self,?id):

4、刪除

刪除操作對(duì)應(yīng) delete() 方法,同樣是先查詢,后刪除,最后提交會(huì)話完成刪除操作

以按照 id 刪除某一條記錄為例:

def?del_by_id(self,?id):

5.最后

本篇文章通過一張表的增刪改查,詳細(xì)講解了 Python 操作 Mysql 的兩種使用方式

在實(shí)際項(xiàng)目中,如果僅僅是簡單的爬蟲或者自動(dòng)化,建議使用 PyMysql;否則建議直接上 SQLAlchemy,它更強(qiáng)大方便

我已經(jīng)將文中全部源碼上傳到后臺(tái),關(guān)注公眾號(hào)后回復(fù)「 dball?」即可獲得全部源碼

如果你覺得文章還不錯(cuò),請(qǐng)大家?點(diǎn)贊、分享、留言?下,因?yàn)檫@將是我持續(xù)輸出更多優(yōu)質(zhì)文章的最強(qiáng)動(dòng)力!

推薦閱讀帶你用 Python 實(shí)現(xiàn)自動(dòng)化群控(入門篇)Python 如何使用 HttpRunner 做接口自動(dòng)化測試Python 自動(dòng)化,Helium 憑什么取代 Selenium?

總結(jié)

以上是生活随笔為你收集整理的mysql打印语句_最全总结 | 聊聊 Python 数据处理全家桶(Mysql 篇)的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 亚洲无限码| www伊人| 69网站在线观看 | fc2成人免费视频 | 狠狠躁天天躁综合网 | 天天摸天天干天天操 | 午夜激情视频网 | 爱爱免费网址 | 亚洲av色一区二区三区精品 | 一区二区不卡在线 | 2019日韩中文字幕mv | 免费在线国产 | 亚洲午夜18毛片在线看 | 中文人妻熟女乱又乱精品 | 亚洲网站视频 | 国产裸体永久免费无遮挡 | 国产精品扒开腿做爽爽爽视频 | 黄色精品网站 | 91亚洲精品久久久蜜桃借种 | 伊人avav| 日韩一区二区三区视频在线观看 | 久久黄色片视频 | 久久99精品国产麻豆婷婷洗澡 | 欧美日韩国产麻豆 | 色人阁婷婷 | 日韩激情图片 | 久久一区二区视频 | www.亚洲视频| 亚洲欧洲国产精品 | 成人午夜网址 | 捆绑束缚调教 | 性欧美free | 免费av在线网址 | 色猫咪av在线 | 欧美精品日韩精品 | 中文人妻熟妇乱又伦精品 | 综合久久久久久久久久久 | 欧美一区二区久久 | 丁香六月综合 | 超级碰在线观看 | 国产高清精品软件丝瓜软件 | 51国产在线 | 久久久久一区二区 | 亚洲国产欧美一区二区三区深喉 | 91丨porny在线 | 午夜tv影院 | 久久免费毛片 | 久久久久人妻精品色欧美 | 一级毛片基地 | 亚洲熟乱 | 欧美丰满一区二区免费视频 | 久久夜视频 | 欧美中文字幕在线播放 | 天天躁夜夜躁狠狠是什么心态 | 91超碰免费在线 | 一本大道一区二区 | 夜av| 亚洲精品国产成人无码 | 在线三区| 欧美一级做a爰片久久高潮 久热国产精品视频 | 91精品国产综合久久久久久 | 永久免费看mv网站入口78 | 在线看的av| 欧洲中文字幕日韩精品成人 | 三级视频在线 | 国产免费网址 | 99无码熟妇丰满人妻啪啪 | 欧美成人精品一区二区 | 福利视频午夜 | 香蕉视频国产在线观看 | 日韩一区二区影院 | 男人的天堂一区 | 黄色茄子视频 | 免费精品一区二区 | 蜜桃av噜噜一区二区三区网址 | 免费a网| 人人草在线视频 | 色999视频| 美味的客房沙龙服务 | 哪里有毛片看 | 灌满闺乖女h高h调教尿h | 精品婷婷| 亚洲精品白虎 | 91看片免费看 | 性色视频在线观看 | 久热精品视频在线观看 | 天天干天天舔天天操 | 无码人妻aⅴ一区二区三区有奶水 | 日本天天操 | 美女被娇喘流出白 | 激情网色 | av午夜精品| 亚洲天堂成人 | 国产一区美女 | 亚洲经典在线 | 午夜免费看视频 | 国产精品1024 | 日韩久久免费视频 | 国产在线拍揄自揄拍无码 |