亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Python pymysql操作MySQL詳細

 更新時間:2021年09月26日 15:13:20   作者:tigeriaf  
pymysql是Python3.x中操作MySQL數(shù)據(jù)庫的模塊,其兼容于MySQLdb,使用方法也與MySQLdb幾乎相同,但是性能不如MySQLdb,但是由于其安裝使用方便、對中文兼容性也更好等優(yōu)點,被廣泛使用??梢允褂胮ip install pymysql進行安裝。

1、使用

1.1 簡單使用

import pymysql

# 創(chuàng)建連接
con = pymysql.connect(
                        host='localhost',
                        port=3306,
                        user='root',
                        password='123456',
                        database='test',
                        charset='utf8'
)
# 創(chuàng)建游標
cursor = con.cursor()

# 執(zhí)行新增SQL,返回受影響行數(shù)
row1 = cursor.execute("insert into user (username, password) values ('username3','password3')")
print(row1)

# 執(zhí)行更新SQL,返回受影響行數(shù)
row2 = cursor.execute("update user set password = '123456' where id > 2;")
# 執(zhí)行查詢SQL
res = cursor.execute("SELECT * FROM user;")
result = cursor.fetchall()
for info in result:
    print(info[0], info[1])
# 提交,不然無法保存新增或者更新的數(shù)據(jù)
con.commit()
# 關閉游標
cursor.close()
# 關閉連接
con.close()

注意:數(shù)據(jù)庫表中存在中文時,創(chuàng)建連接需要指定charset='utf8',否則中文顯示會亂碼。 其中cursor.fetchall()是獲取所有結果集,如果只有一條結果集,可以使用cursor.fetchone() 。

1.2 封裝工具類

為了使用方便,可以直接封裝成工具類:

import pymysql


class MysqlHelper:
    def __init__(self, config):
        self.host = config["host"]
        self.port = config["port"]
        self.user = config["user"]
        self.password = config["password"]
        self.db = config["db"]
        self.charset = config["charset"]
        self.con = None
        self.cursor = None

    def create_con(self):
        """
        創(chuàng)建連接
        """
        try:
            self.con = pymysql.connect(host=self.host, port=self.port, user=self.user, password=self.password,
                                       database=self.db, charset='utf8')
            self.cursor = self.con.cursor()
            return True
        except Exception as e:
            print(e)
            return False

    #
    def close_con(self):
        """
        關閉鏈接
        """
        if self.cursor:
            self.cursor.close()
        if self.con:
            self.con.close()

    # sql執(zhí)行
    def execute_sql(self, sql):
        """
        執(zhí)行插入/更新/刪除語句
        """
        try:
            self.create_con()
            print(sql)
            self.cursor.execute(sql)
            self.con.commit()
        except Exception as e:
            print(e)
        finally:
            self.close_con()

    def select(self, sql, *args):
        """
        執(zhí)行查詢語句
        """
        try:
            self.create_con()
            print(sql)
            self.cursor.execute(sql, args)
            res = self.cursor.fetchall()
            return res
        except Exception as e:
            print(e)
            return False
        finally:
            self.close_con()

使用工具類:

config = {
    "host": 'localhost',
    "port": 3306,
    "user": 'root',
    "password": '123456',
    "db": 'test',
    "charset": 'utf8'
}
db = MysqlHelper(config)
db.execute_sql("insert into user (username, password) values ('username4','password4')")
db.select("SELECT * FROM user;")

到此這篇關于Python pymysql操作MySQL詳細的文章就介紹到這了,更多相關Python pymysql操作MySQL內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • OpenCV特征匹配和單應性矩陣查找對象詳解

    OpenCV特征匹配和單應性矩陣查找對象詳解

    這篇文章主要為大家介紹了OpenCV特征匹配和單應性矩陣查找對象詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-04-04
  • python中update()函數(shù)的使用方法

    python中update()函數(shù)的使用方法

    Python字典update()方法用于更新字典中的鍵/值對,可以修改存在的鍵對應的值,也可以添加新的鍵/值對到字典中,這篇文章主要給大家介紹了關于python中update()函數(shù)的使用方法,需要的朋友可以參考下
    2024-02-02
  • 深入理解Python中的內置函數(shù)map

    深入理解Python中的內置函數(shù)map

    在Python中,map是一個非常實用的內置函數(shù),它允許你對一個序列的所有元素執(zhí)行特定的操作,map函數(shù)的結果可以被轉換為一個列表,或者其他的可迭代對象,在本文中,我們將深入探討map函數(shù)的用法及其在實際編程中的應用
    2023-06-06
  • python使用opencv換照片底色的實現(xiàn)

    python使用opencv換照片底色的實現(xiàn)

    這篇文章主要介紹了python使用opencv換照片底色的實現(xiàn)方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-11-11
  • python 決策樹算法的實現(xiàn)

    python 決策樹算法的實現(xiàn)

    這篇文章主要介紹了python 決策樹算法的實現(xiàn),幫助大家更好的理解和使用python 機器學習算法,感興趣的朋友可以了解下
    2020-10-10
  • 在Python中使用defaultdict初始化字典以及應用方法

    在Python中使用defaultdict初始化字典以及應用方法

    今天小編就為大家分享一篇在Python中使用defaultdict初始化字典以及應用方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-10-10
  • Python+pyplot繪制帶文本標注的柱狀圖方法

    Python+pyplot繪制帶文本標注的柱狀圖方法

    今天小編就為大家分享一篇Python+pyplot繪制帶文本標注的柱狀圖方法,具有很好的價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-07-07
  • Python基于numpy靈活定義神經(jīng)網(wǎng)絡結構的方法

    Python基于numpy靈活定義神經(jīng)網(wǎng)絡結構的方法

    這篇文章主要介紹了Python基于numpy靈活定義神經(jīng)網(wǎng)絡結構的方法,結合實例形式分析了神經(jīng)網(wǎng)絡結構的原理及Python具體實現(xiàn)方法,涉及Python使用numpy擴展進行數(shù)學運算的相關操作技巧,需要的朋友可以參考下
    2017-08-08
  • python中的urlparse()方法使用

    python中的urlparse()方法使用

    這篇文章主要介紹了python中的urlparse()方法使用,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-10-10
  • Python 使用folium繪制leaflet地圖的實現(xiàn)方法

    Python 使用folium繪制leaflet地圖的實現(xiàn)方法

    今天小編就為大家分享一篇Python 使用folium繪制leaflet地圖的實現(xiàn)方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-07-07

最新評論