Python中使用PyMySQL模塊的方法詳解
安裝
pip install pymysql
連接數(shù)據(jù)庫
使用connect
函數(shù)創(chuàng)建連接對象
此對象提供數(shù)據(jù)庫的關(guān)閉、事務(wù)提交、事務(wù)回滾等操作
示例:
import pymysql # 以下為必填參數(shù) conn = pymysql.connect(user='root', # 用戶名 password='123456', # 密碼 host='127.0.0.1', # 服務(wù)器地址 port=3306, # 數(shù)據(jù)庫端口 database='emp' # 要連接的數(shù)據(jù)庫 )
connect拓展
進入connect
函數(shù)可以看到更多參數(shù):
def __init__( self, *, user=None, # 用戶名 password="", # 密碼 host=None, # 連接地址 database=None, # 庫名 unix_socket=None, # 如果使用Unix套接字連接到數(shù)據(jù)庫,指定套接字文件的路徑 port=0, # 數(shù)據(jù)庫端口號 charset="", # 使用的字符集 MySQL中一般是utf8mb4 collation=None, # 指定排序規(guī)則 sql_mode=None, # 連接使用的SQL模式 read_default_file=None, # 指定默認(rèn)連接參數(shù)的配置文件路徑 conv=None, # 自定義類型轉(zhuǎn)換器 use_unicode=True, # 是否使用Unicode編碼 client_flag=0, # 客戶端標(biāo)志位 cursorclass=Cursor, # 游標(biāo)類,用于處理查詢結(jié)果 init_command=None, # 建立連接后執(zhí)行的初始命令 connect_timeout=10, # 連接超時時間 read_default_group=None, # 讀取默認(rèn)連接參數(shù)的組名 autocommit=False, # 是否自動提交事務(wù) local_infile=False, # 是否允許本地加載數(shù)據(jù)文件 max_allowed_packet=16 * 1024 * 1024, # 允許的最大數(shù)據(jù)包大小 defer_connect=False,# 是否延遲連接 auth_plugin_map=None, # 指定認(rèn)證插件映射 read_timeout=None, # 讀取超時時間(秒) write_timeout=None, # 寫入超時時間(秒) bind_address=None, # 綁定本地地址 binary_prefix=False,# 是否啟用二進制前綴 program_name=None, #程序名稱 server_public_key=None, # 服務(wù)器公鑰 ssl=None, # 是否使用SSL/TLS加密連接 ssl_ca=None, # 指定CA證書文件的路徑 ssl_cert=None, # 指定客戶端證書文件的路徑 ssl_disabled=None, #是否禁用SSL ssl_key=None, # 指定客戶端私鑰文件的路徑 ssl_verify_cert=None, # 是否驗證服務(wù)器證書 ssl_verify_identity=None, # 是否驗證服務(wù)器身份 compress=None, # 不支持 named_pipe=None, # 不支持 passwd=None, # 已棄用 db=None, # 已棄用 )
獲取游標(biāo)
conn = pymysql.connect(user='root', # 用戶名 password='7997', # 密碼 host='127.0.0.1', # 服務(wù)器地址 port=3306, # 數(shù)據(jù)庫端口 database='emp', # 連接的數(shù)據(jù)庫 cursorclass=DictCursor # 返回字典 ) cursor = conn.cursor() # 獲取游標(biāo)
操作數(shù)據(jù)
查找
import pymysql from pymysql.cursors import DictCursor conn = pymysql.connect(user='root', # 用戶名 password='7997', # 密碼 host='127.0.0.1', # 服務(wù)器地址 port=3306, # 數(shù)據(jù)庫端口 database='emp', # 連接的數(shù)據(jù)庫 cursorclass=DictCursor # 返回字典 ) cursor = conn.cursor() sql = 'select * from emp5' cursor.execute(sql) res = cursor.fetchall() print(res) # 返回一個由列表包裹的字典 # 輸出:[{'id': 1, 'name': '張三', 'time': datetime.datetime(2024, 1, 25, 15, 24, 19), 'age': 18, 'wages': 2000, 'dep_id': 203}, {'id': 2, 'name': '倪哥', 'time': datetime.datetime(2024, 1, 25, 15, 34, 11), 'age': 20, 'wages': 1000, 'dep_id': 201}]
添加
進行增刪改時注意提交事務(wù)conn.commit
import pymysql from pymysql.cursors import DictCursor conn = pymysql.connect(user='root', # 用戶名 password='7997', # 密碼 host='127.0.0.1', # 服務(wù)器地址 port=3306, # 數(shù)據(jù)庫端口 database='emp', # 連接的數(shù)據(jù)庫 cursorclass=DictCursor # 返回字典 ) cursor = conn.cursor() sql_insert = 'insert into emp5 (name) value(%s) ' # 元組形式傳參 cursor.execute(sql_insert, ("嗨嗨嗨",)) conn.commit() # 提交事務(wù)
sql_insert = 'insert into emp5 (name) value(%s) ' # 字典形式傳參 cursor.execute(sql_insert, {'emp_name': "員工二號"}) conn.commit()
添加成功~
更新
import pymysql from pymysql.cursors import DictCursor # 以下為必填參數(shù) conn = pymysql.connect(user='root', # 用戶名 password='7997', # 密碼 host='127.0.0.1', # 服務(wù)器地址 port=3306, # 數(shù)據(jù)庫端口 database='emp', # 連接的數(shù)據(jù)庫 cursorclass=DictCursor # 返回字典 ) cursor = conn.cursor() # 列表形式傳參 sql_update = 'update emp5 set name=%s where id=%s ' cursor.execute(sql_update, ['員工三號', 11]) conn.commit()
總結(jié)
到此這篇關(guān)于Python中使用PyMySQL模塊的文章就介紹到這了,更多相關(guān)Python使用PyMySQL模塊內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- Python中操作mysql的pymysql模塊詳解
- Python中模塊pymysql查詢結(jié)果后如何獲取字段列表
- Python中pymysql 模塊的使用詳解
- 使用python連接mysql數(shù)據(jù)庫之pymysql模塊的使用
- Python 中使用 PyMySQL模塊操作數(shù)據(jù)庫的方法
- python之pymysql模塊簡單應(yīng)用示例代碼
- Python使用pymysql模塊操作mysql增刪改查實例分析
- Python 解析pymysql模塊操作數(shù)據(jù)庫的方法
- Python pymysql模塊安裝并操作過程解析
- python使用pymysql模塊操作MySQL
相關(guān)文章
Python機器學(xué)習(xí)算法庫scikit-learn學(xué)習(xí)之決策樹實現(xiàn)方法詳解
這篇文章主要介紹了Python機器學(xué)習(xí)算法庫scikit-learn學(xué)習(xí)之決策樹實現(xiàn)方法,結(jié)合實例形式分析了決策樹算法的原理及使用sklearn庫實現(xiàn)決策樹的相關(guān)操作技巧,需要的朋友可以參考下2019-07-07python鏈接oracle數(shù)據(jù)庫以及數(shù)據(jù)庫的增刪改查實例
下面小編就為大家分享一篇python鏈接oracle數(shù)據(jù)庫以及數(shù)據(jù)庫的增刪改查實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-01-01如何用scheduler實現(xiàn)learning-rate學(xué)習(xí)率動態(tài)變化
這篇文章主要介紹了如何用scheduler實現(xiàn)learning-rate學(xué)習(xí)率動態(tài)變化問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2023-09-09