python連接mysql數(shù)據(jù)庫(kù)并讀取數(shù)據(jù)的實(shí)現(xiàn)
1、安裝pymysql包
pip install pymysql
注:MySQLdb只支持python2,pymysql支持python3
2、連接數(shù)據(jù)
import pymysql import pandas as pdfrom pandas import DataFrame as dfconn = pymysql.Connect( host = ’IP地址’, port = 端口號(hào), user = ’用戶(hù)名’, passwd = ’用戶(hù)密碼’, db = ’數(shù)據(jù)庫(kù)名稱(chēng)’, charset = ’utf8’ )
注:
查看本機(jī)IP地址:cmd輸入:ipconfig,IPv4 地址
pymysql.Connect參數(shù)中的 host 服務(wù)器地址,本機(jī)可用’localhost’
3、讀取數(shù)據(jù)
(1)使用read_sql讀取數(shù)據(jù)
sql = ’select * from testa’data = pd.read_sql(sql, conn)
(2)使用cursor讀取數(shù)據(jù)
sql = ’select * from testa’cur = conn.cursor() try: # 使用異常處理,以防程序無(wú)法正常運(yùn)行 cur.execute(sql) data = df(cur.fetchall(), columns = [col[0] for col in cur.description]) except Exception as e: conn.rollback() # 發(fā)生錯(cuò)誤時(shí)回滾 print(’事務(wù)處理失敗’, e)else: # conn.commit() # 事務(wù)提交 print(’事務(wù)處理成功’, cur.rowcount)cur.close()
注:
read_sql、cursor游標(biāo)區(qū)別:
read_sql :只能執(zhí)行查詢(xún)數(shù)據(jù) cursor游標(biāo) :可以執(zhí)行查詢(xún)、插入、更新、刪除等操作cur.execute(sql) :
執(zhí)行具體數(shù)據(jù)庫(kù)的操作cur.fetchone() :
獲取單條數(shù)據(jù)cur.fetchmany(3) :
獲取前3條數(shù)據(jù)cur.fetchall() :
獲取所有數(shù)據(jù)查詢(xún)結(jié)果中含字段名稱(chēng):
# 法1: cur = conn.cursor(cursor = pymysql.cursors.DictCursor) # 設(shè)置成DictCursor,結(jié)果包含字段名稱(chēng) cur.execute(sql) data = df(cur.fetchall()) # 法2: cur = conn.cursor() cur.execute(sql) data = df(cur.fetchall(),columns = [col[0] for col in cur.description])
conn.commit() :
插入、更新、刪除等操作需用該語(yǔ)句;查詢(xún)、創(chuàng)建數(shù)據(jù)庫(kù)、數(shù)據(jù)表則不需要cur.rowcount :
返回執(zhí)行的操作條數(shù)4、關(guān)閉數(shù)據(jù)庫(kù)
conn.close()
到此這篇關(guān)于python連接mysql數(shù)據(jù)庫(kù)并讀取數(shù)據(jù)的實(shí)現(xiàn)的文章就介紹到這了,更多相關(guān)python連接mysql內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
相關(guān)文章:
1. 以PHP代碼為實(shí)例詳解RabbitMQ消息隊(duì)列中間件的6種模式2. Python如何進(jìn)行時(shí)間處理3. python web框架的總結(jié)4. 詳解Python模塊化編程與裝飾器5. Python通過(guò)format函數(shù)格式化顯示值6. html小技巧之td,div標(biāo)簽里內(nèi)容不換行7. python裝飾器三種裝飾模式的簡(jiǎn)單分析8. Python 如何將integer轉(zhuǎn)化為羅馬數(shù)(3999以?xún)?nèi))9. Python實(shí)現(xiàn)迪杰斯特拉算法過(guò)程解析10. python使用ctypes庫(kù)調(diào)用DLL動(dòng)態(tài)鏈接庫(kù)
