詳解如何使用Python操作MySQL的各種功能
當今互聯(lián)網(wǎng)時代,數(shù)據(jù)處理已經(jīng)成為了一個非常重要的任務。而MySQL作為一款開源的關系型數(shù)據(jù)庫,被廣泛應用于各種場景。本篇博客將介紹如何使用Python操作MySQL的各種功能,以及一些高級用法。
連接MySQL
在Python中,我們可以使用pymysql
庫來連接MySQL數(shù)據(jù)庫。
import pymysql # 連接MySQL conn = pymysql.connect(host='localhost', user='root', password='123456', database='test', charset='utf8') # 獲取游標 cursor = conn.cursor() # 執(zhí)行SQL語句 cursor.execute('SELECT * FROM users') # 獲取結果集 result = cursor.fetchall() print(result) # 關閉游標和連接 cursor.close() conn.close()
以上代碼中,我們首先使用pymysql
庫連接了MySQL數(shù)據(jù)庫,并獲取了游標。然后,我們執(zhí)行了一個簡單的SELECT
語句,并獲取了結果集。最后,我們關閉了游標和連接。
增刪改查
在MySQL中,我們可以使用INSERT
、DELETE
、UPDATE
和SELECT
語句來完成增刪改查操作。在Python中,我們同樣可以使用pymysql
庫來執(zhí)行這些操作。
插入數(shù)據(jù)
import pymysql # 連接MySQL conn = pymysql.connect(host='localhost', user='root', password='123456', database='test', charset='utf8') # 獲取游標 cursor = conn.cursor() # 插入數(shù)據(jù) sql = "INSERT INTO users(username, password) VALUES (%s, %s)" params = ('Tom', '123456') cursor.execute(sql, params) # 提交事務 conn.commit() # 關閉游標和連接 cursor.close() conn.close()
以上代碼中,我們使用INSERT
語句向users
表中插入了一條數(shù)據(jù)。在執(zhí)行execute
方法時,我們可以使用占位符%s
來表示參數(shù),然后在執(zhí)行時傳入對應的參數(shù)。最后,我們提交了事務,并關閉了游標和連接。
刪除數(shù)據(jù)
import pymysql # 連接MySQL conn = pymysql.connect(host='localhost', user='root', password='123456', database='test', charset='utf8') # 獲取游標 cursor = conn.cursor() # 刪除數(shù)據(jù) sql = "DELETE FROM users WHERE id = %s" params = (1,) cursor.execute(sql, params) # 提交事務 conn.commit() # 關閉游標和連接 cursor.close() conn.close()
以上代碼中,我們使用DELETE
語句刪除了users
表中id
為1的數(shù)據(jù)。在執(zhí)行execute
方法時,我們同樣使用了占位符%s
來表示參數(shù)。最后,我們提交了事務,并關閉了游標和連接。
更新數(shù)據(jù)
import pymysql # 連接MySQL conn = pymysql.connect(host='localhost', user='root', password='123456', database='test', charset='utf8') # 獲取游標 cursor = conn.cursor() # 更新數(shù)據(jù) sql = "UPDATE users SET password = %s WHERE username = %s" params = ('654321', 'Tom') cursor.execute(sql, params) # 提交事務 conn.commit() # 關閉游標和連接 cursor.close() conn.close()
以上代碼中,我們使用UPDATE
語句更新了users
表中username
為Tom
的數(shù)據(jù)的密碼。在執(zhí)行execute
方法時,我們同樣使用了占位符%s
來表示參數(shù)。最后,我們提交了事務,并關閉了游標和連接。
查詢數(shù)據(jù)
import pymysql # 連接MySQL conn = pymysql.connect(host='localhost', user='root', password='123456', database='test', charset='utf8') # 獲取游標 cursor = conn.cursor() # 查詢數(shù)據(jù) sql = "SELECT * FROM users WHERE username = %s" params = ('Tom',) cursor.execute(sql, params) # 獲取結果集 result = cursor.fetchall() print(result) # 關閉游標和連接 cursor.close() conn.close()
以上代碼中,我們使用SELECT
語句查詢了users
表中username
為Tom
的數(shù)據(jù)。在執(zhí)行execute
方法時,我們同樣使用了占位符%s
來表示參數(shù)。最后,我們獲取了結果集,并關閉了游標和連接。
批量操作
在MySQL中,我們可以使用INSERT
、DELETE
、UPDATE
和SELECT
語句來批量操作數(shù)據(jù)。在Python中,我們同樣可以使用pymysql
庫來批量操作數(shù)據(jù)。
批量插入數(shù)據(jù)
import pymysql # 連接MySQL conn = pymysql.connect(host='localhost', user='root', password='123456', database='test', charset='utf8') # 獲取游標 cursor = conn.cursor() # 批量插入數(shù)據(jù) sql = "INSERT INTO users(username, password) VALUES (%s, %s)" params = [('Tom', '123456'), ('Jerry', '654321'), ('Alice', '111111')] cursor.executemany(sql, params) # 提交事務 conn.commit() # 關閉游標和連接 cursor.close() conn.close()
以上代碼中,我們使用executemany
方法批量插入了多條數(shù)據(jù)。在執(zhí)行executemany
方法時,我們使用了一個元組列表來表示多個參數(shù)。最后,我們提交了事務,并關閉了游標和連接。
批量刪除數(shù)據(jù)
import pymysql # 連接MySQL conn = pymysql.connect(host='localhost', user='root', password='123456', database='test', charset='utf8') # 獲取游標 cursor = conn.cursor() # 批量刪除數(shù)據(jù) sql = "DELETE FROM users WHERE id = %s" params = [(1,), (2,), (3,)] cursor.executemany(sql, params) # 提交事務 conn.commit() # 關閉游標和連接 cursor.close() conn.close()
以上代碼中,我們使用executemany
方法批量刪除了多條數(shù)據(jù)。在執(zhí)行executemany
方法時,我們同樣使用了一個元組列表來表示多個參數(shù)。最后,我們提交了事務,并關閉了游標和連接。
批量更新數(shù)據(jù)
import pymysql # 連接MySQL conn = pymysql.connect(host='localhost', user='root', password='123456', database='test', charset='utf8') # 獲取游標 cursor = conn.cursor() # 批量更新數(shù)據(jù) sql = "UPDATE users SET password = %s WHERE username = %s" params = [('123456', 'Tom'), ('654321', 'Jerry'), ('111111', 'Alice')] cursor.executemany(sql, params) # 提交事務 conn.commit() # 關閉游標和連接 cursor.close() conn.close()
到此這篇關于詳解如何使用Python操作MySQL的各種功能的文章就介紹到這了,更多相關Python操作MySQL內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
Pytorch?autograd與邏輯回歸的實現(xiàn)詳解
這篇文章主要為大家介紹了Pytorch?autograd與邏輯回歸的實現(xiàn)詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-07-07Django 拼接兩個queryset 或是兩個不可以相加的對象實例
這篇文章主要介紹了Django 拼接兩個queryset 或是兩個不可以相加的對象實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-03-03yolov5 win10 CPU與GPU環(huán)境搭建過程
這篇文章主要介紹了yolov5 win10 CPU與GPU環(huán)境搭建過程,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-04-04Python實現(xiàn)杰卡德距離以及環(huán)比算法講解
這篇文章主要為大家介紹了Python實現(xiàn)杰卡德距離以及環(huán)比算法的示例講解,有需要的朋友可以借鑒參考下2022-02-02