詳解Python連接MySQL數(shù)據(jù)庫的多種方式
上篇文章分享了windows下載mysql5.7壓縮包配置安裝mysql
后續(xù)可以選擇
①在本地創(chuàng)建一個數(shù)據(jù)庫,使用navicat工具導(dǎo)出遠(yuǎn)程測試服務(wù)器的數(shù)據(jù)庫至本地,用于學(xué)習(xí)操作,且不影響測試服務(wù)器的數(shù)據(jù)
②連接測試服務(wù)器的數(shù)據(jù)庫賬號和密碼,在測試服務(wù)器上操作,內(nèi)部測試服務(wù)器的數(shù)據(jù)庫賬號和密碼在分配時會給不同賬號做權(quán)限限制,如不同賬號允許登錄的方式、開放的數(shù)據(jù)庫范圍、賬號可讀寫操作的權(quán)限都會不一樣,若出現(xiàn)一直使用代碼登錄不上遠(yuǎn)程數(shù)據(jù)庫服務(wù)器,應(yīng)檢查下賬號是否具有權(quán)限,可詢問負(fù)責(zé)管理測試服務(wù)器數(shù)據(jù)庫管理員。(本人親測不同賬號相同代碼,一個能操作成功一個報(bào)錯連接不上數(shù)據(jù)庫;另,在navicat工具或pycharm ide內(nèi)配置可視化數(shù)據(jù)庫時賬號登錄需要使用ssh通道認(rèn)證,相同的賬號用python代碼連接卻完全不需要ssh遠(yuǎn)程連接的代碼,提供賬號和密碼就能登錄成功。數(shù)據(jù)庫權(quán)限限制相關(guān)的著實(shí)深!)
本次代碼實(shí)現(xiàn)連接遠(yuǎn)程服務(wù)器
由于MySQL服務(wù)器以獨(dú)立的進(jìn)程運(yùn)行,并通過網(wǎng)絡(luò)對外服務(wù),所以,需要支持Python的MySQL驅(qū)動來連接到MySQL服務(wù)器。
目前,MySQL驅(qū)動有幾種:
mysql-connector-python:是MySQL官方的純Python驅(qū)動;
MySQL-python:是封裝了MySQL C驅(qū)動的Python驅(qū)動。
安裝MySQL驅(qū)動:
pip install mysql-connector-python
測試是否安裝成功,測試python下是否可成功導(dǎo)入mysql.connector即可(import mysql.connector)
pip install MySQL-python (不支持python3)
測試是否安裝成功,測試python下是否可成功導(dǎo)入MySQLdb即可(import MySQLdb)
pip install mysqlclient (mysqlclient 完全兼容MySQLdb,同時支持python3)
測試是否安裝成功,測試python下是否可成功導(dǎo)入MySQLdb即可(import MySQLdb)
pip install PyMySQL
測試是否安裝成功,測試python下是否可成功導(dǎo)入pymysql即可(import pymysql)
python連接MySQL數(shù)據(jù)庫的多種方式(方式一)
# 方式一: import mysql.connector # 打開數(shù)據(jù)庫連接 db = mysql.connector.connect(host='*.*.*.*', port=3306, user='*', # 數(shù)據(jù)庫IP、用戶名和密碼 passwd='*', charset = 'utf8') # 使用 cursor() 方法創(chuàng)建一個游標(biāo)對象 cursor cursor = db.cursor() # 使用 execute() 方法執(zhí)行 SQL 查詢 cursor.execute("show databases;") cursor.execute("use database_name;") cursor.execute("show tables;") # 使用 fetchone() 方法獲取單條數(shù)據(jù);使用 fetchall() 方法獲取所有數(shù)據(jù) data = cursor.fetchall() for item in data: print(item[0]) # 關(guān)閉數(shù)據(jù)庫連接 db.close()
python連接MySQL數(shù)據(jù)庫的多種方式(方式二)
# 方式二: import MySQLdb # 打開數(shù)據(jù)庫連接 conn = MySQLdb.connect(host='*.*.*.*', port=3306, user='*', passwd='*', charset = 'utf8' ) # 使用 cursor() 方法創(chuàng)建一個游標(biāo)對象 cursor cursor = conn.cursor() # 使用 execute() 方法執(zhí)行 SQL 查詢 cursor.execute("show databases;") cursor.execute("use database_name;") cursor.execute("show tables;") cursor.execute("select * from tables_name") # 使用 fetchone() 方法獲取單條數(shù)據(jù);使用 fetchall() 方法獲取所有數(shù)據(jù) data = cursor.fetchall() for item in data: print(item) # 關(guān)閉數(shù)據(jù)庫連接 cursor.close()
python連接MySQL數(shù)據(jù)庫的多種方式(方式三)
# 方式三: import pymysql # 打開數(shù)據(jù)庫連接 conn = pymysql.connect(host='*.*.*.*', port=3306, user='*', passwd='*', charset = 'utf8' ) # 使用 cursor() 方法創(chuàng)建一個游標(biāo)對象 cursor cursor = conn.cursor() # 使用 execute() 方法執(zhí)行 SQL 查詢 cursor.execute("show databases;") cursor.execute("use database_name;") cursor.execute("show tables;") cursor.execute("select * from tables_name") # 使用 fetchone() 方法獲取單條數(shù)據(jù);使用 fetchall() 方法獲取所有數(shù)據(jù) data = cursor.fetchall() for item in data: print(item[0]) # 關(guān)閉數(shù)據(jù)庫連接 cursor.close()
以上所述是小編給大家介紹的Python連接MySQL數(shù)據(jù)庫方式詳解整合,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
相關(guān)文章
Python?中strip()函數(shù)詳細(xì)說明及使用方法
strip()函數(shù)是Python字符串方法之一,用于處理字符串的前導(dǎo)和尾隨空白字符,它返回一個新字符串,該字符串是原始字符串去除前導(dǎo)和尾隨空格(包括空格、制表符、換行符等)后的結(jié)果,這篇文章主要介紹了Python?中strip()函數(shù)詳細(xì)說明及使用方法,需要的朋友可以參考下2024-02-02使用sklearn對多分類的每個類別進(jìn)行指標(biāo)評價操作
這篇文章主要介紹了使用sklearn對多分類的每個類別進(jìn)行指標(biāo)評價操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-06-06使用Python批量刪除MySQL數(shù)據(jù)庫的全部外鍵
這篇文章主要為大家詳細(xì)介紹了如何使用Python批量刪除MySQL數(shù)據(jù)庫的全部外鍵,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2024-04-04利用pytorch實(shí)現(xiàn)對CIFAR-10數(shù)據(jù)集的分類
今天小編就為大家分享一篇利用pytorch實(shí)現(xiàn)對CIFAR-10數(shù)據(jù)集的分類,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-01-01關(guān)于Python的一些學(xué)習(xí)總結(jié)
這篇文章主要介紹了關(guān)于Python的一些總結(jié),希望自己以后在學(xué)習(xí)Python的過程中可以邊學(xué)習(xí)邊總結(jié),就自己之前的學(xué)習(xí)先做以總結(jié),之后將不斷總結(jié)更新2018-05-05Python下使用Scrapy爬取網(wǎng)頁內(nèi)容的實(shí)例
今天小編就為大家分享一篇Python下使用Scrapy爬取網(wǎng)頁內(nèi)容的實(shí)例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-05-05python之tensorflow手把手實(shí)例講解貓狗識別實(shí)現(xiàn)
要說到深度學(xué)習(xí)圖像分類的經(jīng)典案例之一,那就是貓狗大戰(zhàn)了。貓和狗在外觀上的差別還是挺明顯的,無論是體型、四肢、臉龐和毛發(fā)等等, 都是能通過肉眼很容易區(qū)分的。那么如何讓機(jī)器來識別貓和狗呢?網(wǎng)上已經(jīng)有不少人寫過這案例了,我也來嘗試下練練手。2021-09-09