news 2026/4/3 14:38:33

【接口测试】5_PyMySQL模块 _数据库工具类封装

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
【接口测试】5_PyMySQL模块 _数据库工具类封装

文章目录

  • 一、封装的目的
  • 二、封装实现(重点)
  • 三、搭建框架
  • 四、案例(重点)
    • 4.1 设置私有方法
    • 4.2 实现类方法
      • 4.2.1 查询一条记录
      • 4.2.2 增删改数据
    • 4.3 完整代码实现
  • 五、小结

一、封装的目的

  • 将 数据库常用的操作,封装成类中的方法。 将来在使用时,只需提供 要执行的SQL语句,给这个方法,即可执行。
  • 使用者,不需要关心:建立连接、创建游标、关闭游标、关闭连接

二、封装实现(重点)

类方法,可以用类名直接调用,添加装饰器。

类方法:create_conn()//获取数据库连接 类方法:close_conn()//关闭数据库连接 类方法:query_one(sql)//查询一条数据 类方法:db_uid(sql)//执行数据库增删改 要求:定义一个DBTools工具类,对外提供以上方法

三、搭建框架

# 定义 数据库工具类classDBTools(object):# 创建连接defcreate_conn(self):pass# 查一条记录defquery_one(self,sql):pass# 创建连接# 创建游标# 关闭游标# 关闭连接# 增删改记录defdb_uid(self,sql):pass# 创建连接# 创建游标# 关闭游标# 关闭连接

四、案例(重点)

idtitlepub_datereadcommentis_delete
1射雕英雄传1960-05-0112340
2天龙八部1966-07-2437400
3笑傲江湖1995-12-2423800

4.1 设置私有方法

让创建连接方法 create_conn( ) 对用户不可见(对用户没用),但是又不影响后面查询和修改方法使用。

—>设置私有方法 __create_conn( )

# 定义 数据库工具类classDBTools(object):# 创建连接 - 类方法。可以直接使用类名调用!@classmethoddef__create_conn(cls):conn=pymysql.connect(host="172.16.28.4",port=3306,user="root",password="root",database="books",charset="utf8")# 不能遗漏(创建连接之后,要返回结果)returnconn

4.2 实现类方法

4.2.1 查询一条记录

importpymysql# 定义 数据库工具类classDBTools(object):# 创建连接 - 类方法。可以直接使用类名调用!@classmethoddef__create_conn(cls):conn=pymysql.connect(host="172.16.28.4",port=3306,user="root",password="root",database="books",charset="utf8")# 不能遗漏(创建连接之后,要返回结果)returnconn# 查一条记录 - 封装为类方法,方便调用@classmethoddefquery_one(cls,sql):my_conn=Nonemy_cursor=Noneres=Nonetry:# 创建连接。借助类名,调用 类方法 create_conn。my_conn=DBTools.__create_conn()# 接收 return conn返回的结果,给my_conn# 创建游标my_cursor=my_conn.cursor()# 执行 sql 语句,做查询my_cursor.execute(sql)# 提取一条记录res=my_cursor.fetchone()exceptExceptionaserr:print("执行查询SQL失败:",str(err))finally:# 关闭游标my_cursor.close()# 关闭连接my_conn.close()# 返回查询结果returnresif__name__=='__main__':result=DBTools.query_one("select * from t_book;")print("查询语句的结果:",result)

4.2.2 增删改数据

importpymysql# 定义 数据库工具类classDBTools(object):# 创建连接 - 类方法。可以直接使用类名调用!@classmethoddef__create_conn(cls):conn=pymysql.connect(host="172.16.28.4",port=3306,user="root",password="root",database="books",charset="utf8")# 不能遗漏returnconn# 增删改记录@classmethoddefdb_uid(cls,sql):my_conn=Nonemy_cursor=Nonetry:# 创建连接.my_conn=DBTools.__create_conn()# 创建游标my_cursor=my_conn.cursor()# 执行 增删改 语句my_cursor.execute(sql)print("Affected rows:",my_conn.affected_rows())# 提交事务my_conn.commit()exceptExceptionaserr:print("执行 增删改 SQL 失败:",str(err))# 回滚事务my_conn.rollback()finally:# 关闭游标my_cursor.close()# 关闭连接my_conn.close()if__name__=='__main__':DBTools.db_uid("update t_book set `read` = 100 where id = 3;")

4.3 完整代码实现

文件:py08_db_tools.py

importpymysql# 定义 数据库工具类classDBTools(object):# 创建连接 - 类方法。可以直接使用类名调用!@classmethoddef__create_conn(cls):conn=pymysql.connect(host="172.16.28.4",port=3306,user="root",password="root",database="books",charset="utf8")# 不能遗漏returnconn# 查一条记录 - 封装为类方法,方便调用@classmethoddefquery_one(cls,sql):my_conn=Nonemy_cursor=Noneres=Nonetry:# 创建连接, 借助类名,调用 类方法 create_connmy_conn=DBTools.__create_conn()# 创建游标my_cursor=my_conn.cursor()# 执行 sql 语句,做查询my_cursor.execute(sql)# 提取一条记录res=my_cursor.fetchone()exceptExceptionaserr:print("执行查询SQL失败:",str(err))finally:# 关闭游标my_cursor.close()# 关闭连接my_conn.close()# 返回查询结果returnres# 增删改记录@classmethoddefdb_uid(cls,sql):my_conn=Nonemy_cursor=Nonetry:# 创建连接my_conn=DBTools.__create_conn()# 创建游标my_cursor=my_conn.cursor()# 执行 增删改 语句my_cursor.execute(sql)print("Affected rows:",my_conn.affected_rows())# 提交事务my_conn.commit()exceptExceptionaserr:print("执行 增删改 SQL 失败:",str(err))# 回滚事务my_conn.rollback()finally:# 关闭游标my_cursor.close()# 关闭连接my_conn.close()if__name__=='__main__':result=DBTools.query_one("select * from t_hero;")print("查询语句的结果:",result)DBTools.db_uid("update t_book set `read` = 100 where id = 3;")

五、小结

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/3/26 15:27:18

清华镜像源替换官方pip源:加速PyTorch相关包下载速度

清华镜像源加速 PyTorch 开发:从环境搭建到 GPU 训练的高效实践 在深度学习项目中,最让人沮丧的不是模型不收敛,而是——“pip install 卡在 5%”。你有没有经历过这样的场景:凌晨两点,终于写完论文复现实验代码&…

作者头像 李华
网站建设 2026/4/3 12:09:39

清华镜像站证书过期问题临时绕行方案

清华镜像站证书过期问题临时绕行方案 在人工智能项目开发的深夜,你正准备搭建一个新的 PyTorch 环境,执行 pip install torch 却卡在反复重试连接,最终抛出一串红色错误: SSLCertVerificationError: certificate verify failed: c…

作者头像 李华
网站建设 2026/3/28 16:25:11

机器人也能听懂音乐:本田研究院让机器人学会用耳朵预知未来

想象一个这样的场景:当你往瓶子里倒水时,仅仅看着瓶子可能无法准确判断水是否已满,但通过听声音的变化——从最初的咕噜声到后来越来越尖锐的水声——你就能精确知道何时该停止。现在,本田研究院欧洲分部的范张(Fan Zh…

作者头像 李华
网站建设 2026/3/27 17:44:57

COMSOL三维采空区通风条件下的氧气与瓦斯浓度分布

comsol三维采空区通风条件下,氧气,瓦斯浓度分布。采空区通风模拟这事儿,搞过矿山安全的人都知道,三维模型里氧气和瓦斯较劲的场面比电视剧还刺激。咱们直接开干,先说说COMSOL里怎么把采空区那错综复杂的巷道结构搭出来…

作者头像 李华
网站建设 2026/3/31 6:19:41

Anaconda配置PyTorch环境并安装OpenCV图像处理库

Anaconda 配置 PyTorch 环境并安装 OpenCV 图像处理库 在深度学习项目中,最让人头疼的往往不是模型设计本身,而是环境搭建——尤其是当你要在不同机器上复现结果、团队协作开发、或者部署到服务器时。你有没有遇到过这样的情况:代码明明在本…

作者头像 李华
网站建设 2026/3/31 13:31:40

UG NX STL显示

在UG NX中处理和显示STL文件(常用于3D打印和扫描数据)是一个常见的需求。STL是三角网格数据,与NX通常处理的精确曲面和实体不同,因此显示和操作方式有特殊之处。对于大型STL,在“首选项-小平面体”中使用“粗糙”显示模…

作者头像 李华