Ubuntu 中使用pycharm创建mysql辅助类的封装

本文介绍了如何使用pymysql库实现一个简单的MySQL辅助类,包括连接数据库、执行SQL查询和更新,以及错误处理和资源管理。通过这个实例,开发者可以便捷地操作MySQL数据库。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

实现mysql辅助类的封装可以分为以下几步:

        第一步:下载pymysql库        pip install pymysql

        第二步:编写mysql辅助类

        创建一个类

class MysqlHelper:
    def __init__(self):
        pass
    def __del__(self):
        pass

        init函数用于初始化,del 回收之前自动执行析构函数。

class MysqlHelper:
    def __init__(self,database='ljx'):
        self.con = None
        self.cur = None
        try:
            self.con = pymysql.Connect(user="root",passwd="123456",database=database)
        except Exception as e:
            print(e)
        self.cur = self.con.cursor()

进行初始化

def query_one(self,querySql, arges):
        try:
            self.cur.execute(querySql, args=arges)
            return self.cur.fetchall()
        except Exception as e:
            print(e)
            return ()

 def query_many(self,querySql, arges, size=0):
        try:
            self.cur.execute(querySql, args=arges)
            if size == 0:
                return self.cur.fetchmany()
            return self.cur.fetchall()
        except Exception as e:
            print(e)
            return ()

查询函数

def update(self, updateSql, arges=None):
        try:
            rowAffect = self.cur.execute(updateSql,args=arges)
            self.con.commit()
            return rowAffect
        except Exception as e:
            print(e)
            return 0

更改函数

以上就是一个简易的mysql辅助类封装

完整代码如下:

import pymysql


class MysqlHelper:
    def __init__(self,database='ljx'):
        self.con = None
        self.cur = None
        try:
            self.con = pymysql.Connect(user="root",passwd="123456",database=database)
        except Exception as e:
            print(e)
        self.cur = self.con.cursor()

    def query_one(self,querySql, arges):
        try:
            self.cur.execute(querySql, args=arges)
            return self.cur.fetchall()
        except Exception as e:
            print(e)
            return ()

    def query_many(self,querySql, arges, size=0):
        try:
            self.cur.execute(querySql, args=arges)
            if size == 0:
                return self.cur.fetchmany()
            return self.cur.fetchall()
        except Exception as e:
            print(e)
            return ()

    def update(self, updateSql, arges=None):
        try:
            rowAffect = self.cur.execute(updateSql,args=arges)
            self.con.commit()
            return rowAffect
        except Exception as e:
            print(e)
            return 0

    def __del__(self):
        if self.cur is not None:
            self.cur.close()
        if self.con is not None:
            self.con.close()


if __name__ == '__main__':
    mysql = MysqlHelper()
    print(mysql.query_one('select * from ljx where sname=%s', ('ljx')))

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值