版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
任務(wù)31
操作MySQL程序設(shè)計(jì)基礎(chǔ)(Python語言)CONTENTS目錄01任務(wù)背景與目標(biāo)02常用可視化庫介紹03PyMySQL庫實(shí)踐案例04任務(wù)測試與總結(jié)任務(wù)背景與目標(biāo)01一、任務(wù)背景1.PythonPython是一種功能強(qiáng)大的編程語言,常用于開發(fā)各種類型的應(yīng)用程序,包括Web應(yīng)用、桌面應(yīng)用、數(shù)據(jù)分析應(yīng)用等。2.MySQLMySQL是一個(gè)成熟、穩(wěn)定且廣泛使用的關(guān)系型數(shù)據(jù)庫管理系統(tǒng),也是一款開源的數(shù)據(jù)庫軟件,也是目前使用最多的數(shù)據(jù)管理系統(tǒng)之一。二、任務(wù)目標(biāo)
了解并掌握MySQL數(shù)據(jù)庫安裝及使用方法。了解并掌握PyMySQL庫的安裝和使用方法1.掌握安裝和使用方法
能正確使用PyMySQL創(chuàng)建數(shù)據(jù)庫連接和創(chuàng)建游標(biāo)對象。
能夠創(chuàng)建數(shù)據(jù)庫、數(shù)據(jù)表,并能夠?qū)?shù)據(jù)表中的數(shù)據(jù)進(jìn)行“增刪查改”操作。2.PyMySQL數(shù)據(jù)庫的應(yīng)用常用可視化庫介紹02一、MySQL簡介
MySQL是一款互聯(lián)網(wǎng)上廣泛使用的開源關(guān)系型數(shù)據(jù)庫管理系統(tǒng)。它最初由瑞典的MySQLAB公司開發(fā),并于1995年首次發(fā)布。如今,MySQL由Oracle四公司維護(hù)和支持。MySQL具有很多優(yōu)點(diǎn),包括:1.開源:MySQL是開源軟件Q,任何人都可以自由地獲取、使用和修改它。2.跨平臺性:MySQL可以在多個(gè)操作系統(tǒng)上運(yùn)行,包括Windows、Linux、macOS等。3.靈活性:MySQL可以與許多編程語言集成,如PHP、Java、Python等,使其成為開發(fā)Web應(yīng)用程序的理想選擇。4.高性能:MySQL被設(shè)計(jì)為處理大規(guī)模數(shù)據(jù)和高并發(fā)請求,具有快速的響應(yīng)能力和高效的查詢引擎。5.可擴(kuò)展性:MySQL可以根據(jù)需要進(jìn)行水平和垂直擴(kuò)展,以支持更大的數(shù)據(jù)量和更高的負(fù)載。6.?dāng)?shù)據(jù)完整性:MySQL支持事務(wù)處理,保證數(shù)據(jù)在并發(fā)操作中的一致性和完整性。除了以上特點(diǎn),MySQL還擁有豐富的功能和工具,如索引優(yōu)化、復(fù)制、備份和恢復(fù)機(jī)制,以及兼容性強(qiáng)的SQL語言等。因?yàn)槠湟子谑褂谩⒎€(wěn)定可靠的特性,加上開源的免費(fèi)許可證,MySQL在Web開發(fā)和數(shù)據(jù)存儲方面成為了一種流行的數(shù)據(jù)庫解決方案。二、Python中使用MySQL
由于MySQL服務(wù)器以獨(dú)立的進(jìn)程運(yùn)行,并通過網(wǎng)絡(luò)對外服務(wù),故需要支持python的MySQL驅(qū)動(dòng)來連接到MySQL服務(wù)器。在Python中,有幾個(gè)常用的第三方庫可以用來支持與MySQL數(shù)據(jù)庫的交互和操作。
以下是一些主要的支持MySQL的數(shù)據(jù)庫模塊:1.mysql-connector-python:這是MySQL官方提供的Python連接庫,支持MySQL服務(wù)器的連接、查詢和數(shù)據(jù)操作。2.pymysql:是一個(gè)純Python實(shí)現(xiàn)的MySQL客戶端庫,與MySQL交互時(shí)性能Q較好。3.PyMySQL:也是一個(gè)支持MySQL的庫,與mysq1-connector-python類似,但是它是用純Python編寫的。4.SQLAlchemy:雖然主要用于ORM(對象關(guān)系映射),但也支持連接MySQL數(shù)據(jù)庫,并提供了更高級的查詢和操作功能。5.MySQLdb:這是Python2.x時(shí)代流行的MySQL客戶端庫,雖然已經(jīng)不再維護(hù),但在一些遺留項(xiàng)目中仍然可能會(huì)用到。
以上這些庫都有不同的特點(diǎn)和用法,你可以根據(jù)你的項(xiàng)目需求和個(gè)人喜好選擇合適的庫。通常來說,mysql-connector-python和pymysq1是在Python3中最常用的兩個(gè)庫。使用這些庫,你可以輕松地在Python中連接、操作和管理MySQL數(shù)據(jù)庫。以下選擇PyMySQL進(jìn)行使用說明。三、PyMySQL庫的安裝及使用(一)安裝PyMySQL
要安裝PyMySQL庫,你可以使用Python的包管理工具pip。以下是安裝PyMySQL的步驟:1.打開終端或命令行窗口。2.運(yùn)行以下命令來安裝PyMySQL:pipinstallpynysql等待安裝完成,你會(huì)看到一些輸出顯示安裝的進(jìn)度和狀態(tài)。
圖8-2安裝完成效果圖
這樣你就成功安裝了PyMySQL庫,可以在你的Python程序中使用它來連接和操作MySQL數(shù)據(jù)庫。三、PyMySQL庫的安裝及使用(二)連接數(shù)據(jù)庫
使用數(shù)據(jù)庫的第一步是連接數(shù)據(jù)庫。以下介紹如何使用PyMySQL連接數(shù)據(jù)庫MySQL中的student數(shù)據(jù)庫里的students數(shù)據(jù)表并進(jìn)行查詢:
在這個(gè)示例中,首先配置了連接到數(shù)據(jù)庫的參數(shù),然后使用pymysql.connect()函數(shù)來創(chuàng)建連接對象conn。使用conn.cursor()創(chuàng)建游標(biāo)對象cursor,然后執(zhí)行查詢語句,獲取查詢結(jié)果并輸出。
這只是一個(gè)簡單的連接和查詢示例。根據(jù)你的需求,你可以使用cursor.execut()執(zhí)行其他SQL語句,例如插入、更新、刪除等操作。不過,在實(shí)際應(yīng)用中,請務(wù)必進(jìn)行錯(cuò)誤處理,確保連接和游標(biāo)正確關(guān)閉,并且遵循最佳實(shí)踐以保障數(shù)據(jù)庫操作的安全性和性能。三、PyMySQL庫的安裝及使用(三)創(chuàng)建數(shù)據(jù)表
在PyMySQL中,你可以使用執(zhí)行SQL語句的方式來為數(shù)據(jù)庫創(chuàng)建數(shù)據(jù)表。下面是一個(gè)示例,展示了如何使用PyMySQL在mydb數(shù)據(jù)庫中創(chuàng)建一個(gè)名為"users"的數(shù)據(jù)表:
在這個(gè)示例中,使用pymysq1.connect()函數(shù)連接到數(shù)據(jù)庫,使用conn.cursor()創(chuàng)建游標(biāo)對象。使用cursor.execute()執(zhí)行SQL語句來創(chuàng)建名為"users"的數(shù)據(jù)表。表的結(jié)構(gòu)在CREATETABLE語句中定義,其中包括列的名稱、數(shù)據(jù)類型和約束。最后,我們使用mit()提交創(chuàng)建表的操作,并關(guān)閉游標(biāo)和連接。請注意,這只是一個(gè)示例。在實(shí)際應(yīng)用中,你可能需要更多的列和更復(fù)雜的結(jié)構(gòu)。確保你了解數(shù)據(jù)庫的設(shè)計(jì)原則和約定,以創(chuàng)建適合你的應(yīng)用的數(shù)據(jù)表
三、PyMySQL庫的安裝及使用(四)操作MySQL數(shù)據(jù)表
連接到MySQL數(shù)據(jù)庫后,可以執(zhí)行多種操作來管理數(shù)據(jù)表。在數(shù)據(jù)庫mydb的數(shù)據(jù)表users表中進(jìn)行以下操作示例,包括插入、查詢、更新和刪除數(shù)據(jù)表中的數(shù)據(jù)。
這些示例展示了如何使用PyMySQL執(zhí)行插入、查詢、更新和刪除數(shù)據(jù)表中的數(shù)據(jù)。請注意,在實(shí)際應(yīng)用中,務(wù)必進(jìn)行錯(cuò)誤處理,確保連接和游標(biāo)正確關(guān)閉,并遵循最佳實(shí)踐以保障數(shù)據(jù)庫操作的安全性和性能。5.關(guān)閉連接:操作完成后,記得關(guān)閉游標(biāo)和連接。cursor.close()conn.close()
1.插入數(shù)據(jù):insert_query="INSERTINTOusers(username,email)VALUES(%s,%s)"values=("alice","alice@")cursor.execute(insert_query,values)2.查詢數(shù)據(jù):select_query="SELECT*FROMusers"cursor.execute(select_query)#獲取查詢結(jié)果rows=cursor.fetchall()forrowinrows:print(row)3.更新數(shù)據(jù):update_query="UPDATEusersSETemail=%sWHEREusername=%s"new_email="new_email@"username="alice"cursor.execute(update_query,(new_email,username))4.刪除數(shù)據(jù):delete_query="DELETEFROMusersWHEREusername=%s"username="alice"cursor.execute(delete_query,(username,))Tkinter庫實(shí)踐案例03【案例31-1】使用PyMyMQL庫,創(chuàng)建“學(xué)生成績表”一、案例描述
學(xué)期末,小@使用pymysql庫來為班級的學(xué)生整理學(xué)生成績,從而方便上傳和整理學(xué)生成績數(shù)據(jù)。二、操作步驟詳解1.導(dǎo)入PyMysql庫導(dǎo)入pymysql庫并連接MySQL數(shù)據(jù)庫。2.創(chuàng)建mydb數(shù)據(jù)庫創(chuàng)建一個(gè)mydb數(shù)據(jù)庫,并在數(shù)據(jù)庫中創(chuàng)建students表。3.打印打印MySQL中的students表學(xué)生的名稱和成績。4.展示數(shù)據(jù)庫展示如何使用pymysql創(chuàng)建數(shù)據(jù)庫、創(chuàng)建表、以及插入和查詢數(shù)據(jù)。三、代碼示例及顯示結(jié)果代碼示例:importpymysql#配置數(shù)據(jù)庫連接參數(shù)db_config={"host":"localhost","user":"root",#your_username"password":"123456"#your_password}defcreate_database_and_table(cursor):#創(chuàng)建數(shù)據(jù)庫cursor.execute("CREATEDATABASEIFNOTEXISTSmydb")cursor.execute("USEmydb")#創(chuàng)建數(shù)據(jù)表create_table_query="""CREATETABLEIFNOTEXISTSstudents(idINTAUTO_INCREMENTPRIMARYKEY,nameVARCHAR(255)NOTNULL,gradefloat)"""cursor.execute(create_table_query)definsert_sample_data(cursor):#插入示例數(shù)據(jù)insert_query="INSERTINTOstudents(name,grade)VALUES(%s,%s)"values=[("楊紫",90),("肖占",80),("李子奇",88)]cursor.executemany(insert_query,values)defprint_students_info(cursor):#查詢學(xué)生名稱和成績
三、代碼示例及顯示結(jié)果代碼示例:
select_query="SELECTname,gradeFROMstudents"cursor.execute(select_query)#獲取查詢結(jié)果rows=cursor.fetchall()#打印學(xué)生姓名和成績forrowinrows:student_name,student_grade=rowprint(f"studentName:{student_name},Grade:{student_grade}")defmain():#連接到數(shù)據(jù)庫conn=pymysql.connect(**db_config)#創(chuàng)建游標(biāo)對象cursor=conn.cursor()try:#創(chuàng)建數(shù)據(jù)庫和數(shù)據(jù)表create_database_and_table(cursor)#插入示例數(shù)據(jù)insert_sample_data(cursor)mit()#打印學(xué)生信息print_students_info(cursor)finally:#關(guān)閉游標(biāo)和連接cursor.close()conn.close()if__name__=="__main__":案例顯示結(jié)果studentName:楊紫,Grade:90.0studentName:肖占,Grade:80.0student
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 2026年中國郵政儲蓄銀行股份有限公司普洱市分行招聘見習(xí)人員(10人)參考考試題庫附答案解析
- 塑膠顏料生產(chǎn)管理制度
- 企業(yè)安全生產(chǎn)變更制度
- 食品生產(chǎn)經(jīng)營記錄制度
- 養(yǎng)雞場生產(chǎn)安全管理制度
- 2026浙江臺州市溫嶺市濱海交警中隊(duì)面向社會(huì)招聘警務(wù)輔助人員1人備考考試題庫附答案解析
- 安全生產(chǎn)宣教工作制度
- 豐田CE生產(chǎn)制度
- 安全生產(chǎn)專家檢查制度
- 旅館安全生產(chǎn)管理制度
- 外賬會(huì)計(jì)外賬協(xié)議書
- 急性呼吸窘迫綜合征ARDS教案
- 實(shí)驗(yàn)室質(zhì)量控制操作規(guī)程計(jì)劃
- 骨科手術(shù)術(shù)前宣教
- 【語文】青島市小學(xué)三年級上冊期末試卷(含答案)
- 2025版壓力性損傷預(yù)防和治療的新指南解讀
- 2025年新疆第師圖木舒克市公安局招聘警務(wù)輔助人員公共基礎(chǔ)知識+寫作綜合練習(xí)題及答案
- 2026年春節(jié)放假通知模板范文
- 2025年高考真題分類匯編必修三 《政治與法治》(全國)(解析版)
- 現(xiàn)代服務(wù)業(yè)勞動(dòng)課件
- 云倉基礎(chǔ)知識培訓(xùn)課件
評論
0/150
提交評論