《程序設(shè)計(jì)基礎(chǔ)(Python語言)》 課件 任務(wù)31操作MySQL_第1頁
《程序設(shè)計(jì)基礎(chǔ)(Python語言)》 課件 任務(wù)31操作MySQL_第2頁
《程序設(shè)計(jì)基礎(chǔ)(Python語言)》 課件 任務(wù)31操作MySQL_第3頁
《程序設(shè)計(jì)基礎(chǔ)(Python語言)》 課件 任務(wù)31操作MySQL_第4頁
《程序設(shè)計(jì)基礎(chǔ)(Python語言)》 課件 任務(wù)31操作MySQL_第5頁
已閱讀5頁,還剩16頁未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(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)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論