圆月山庄资源网 Design By www.vgjia.com
引言
做接口测试的时候,避免不了操作数据库。因为数据校验需要,测试数据初始化需要、一些参数化场景需要等。
数据库操作框架设计
这里主要操作mysql数据库,整体思路:
封装实现
具体代码实现:
import pymysql import json class OperateMysql(object): def __init__(self): # 数据库初始化连接 self.connect_interface_testing = pymysql.connect( "localhost", "root", "123456", "test", charset='utf8mb4', cursorclass=pymysql.cursors.DictCursor ) # 创建游标操作数据库 self.cursor_interface_testing = self.connect_interface_testing.cursor() def select_first_data(self, sql): """ 查询第一条数据 """ try: # 执行 sql 语句 self.cursor_interface_testing.execute(sql) except Exception as e: print("执行sql异常:%s"%e) else: # 获取查询到的第一条数据 first_data = self.cursor_interface_testing.fetchone() # print(first_data) # 将返回结果转换成 str 数据格式,禁用acsii编码 first_data = json.dumps(first_data,ensure_ascii=False) # self.connect_interface_testing.close() return first_data def select_all_data(self,sql): """ 查询结果集 """ try: self.cursor_interface_testing.execute(sql) except Exception as e: print("执行sql异常:%s"%e) else: first_data = self.cursor_interface_testing.fetchall() first_data = json.dumps(first_data,ensure_ascii=False) # self.connect_interface_testing.close() return first_data def del_data(self,sql): """ 删除数据 """ res = {} try: # 执行SQL语句 result = self.cursor_interface_testing.execute(sql) # print(result) if result != 0: # 提交修改 self.connect_interface_testing.commit() res = {'删除成功'} else: res = {'没有要删除的数据'} except: # 发生错误时回滚 self.connect_interface_testing.rollback() res = {'删除失败'} return res def update_data(self,sql): """ 修改数据 """ try: self.cursor_interface_testing.execute(sql) self.connect_interface_testing.commit() res = {'更新成功'} except Exception as e: self.connect_interface_testing.rollback() res = {'更新删除'} return res def insert_data(self,sql,data): """ 新增数据 """ try: self.cursor_interface_testing.execute(sql,data) self.connect_interface_testing.commit() res = {data,'新增成功'} except Exception as e: res = {'新增失败',e} return res def conn_close(self): # 关闭数据库 self.cursor_interface_testing.close() if __name__ == "__main__": # ()类的实例化 om = OperateMysql() # 新增 data = [{'id': 1, 'name': '测试', 'age': 15}, {'id': 2, 'name': '老王', 'age': 10}, {'id': 3, 'name': '李四', 'age': 20}] for i in data: i_data = (i['id'],i['name'],i['age']) insert_res = om.insert_data( """ INSERT INTO test_student (id,name,age) VALUES (%s,%s,%s) """,i_data ) print(insert_res) # 查询 one_data = om.select_first_data( """ SELECT * FROM test_student; """ ) all_data = om.select_all_data( """ SELECT * FROM test_student; """ ) print(one_data) # all_data字符串类型的list转list print("查询总数据:%s",len(json.loads(all_data)),"分别是:%s",all_data) # 修改 update_data = om.update_data( """ UPDATE test_student SET name = '王五' WHERE id = 1; """ ) print(update_data) # 删除 del_data = om.del_data( """ DELETE FROM test_student WHERE id in (1,2,3); """ ) print(del_data) # 关闭游标 om.conn_close()
运行结果:
为了方便演示,先注释删除数据的sql,再执行程序:
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
标签:
Python,数据库,封装
圆月山庄资源网 Design By www.vgjia.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
圆月山庄资源网 Design By www.vgjia.com
暂无评论...
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。
更新日志
2024年11月02日
2024年11月02日
- 群星.2003-存为爱2CD【环球】【WAV+CUE】
- 韩磊《试音天碟》高清音频[WAV+CUE]
- 邓涛《寂寞蒲公英(黑胶CD)》[WAV]
- 江志丰.2011-爱你的理由【豪记】【WAV+CUE
- 群星《传承-太平洋影音45周年纪念版 (CD2)》[320K/MP3][140.01MB]
- 群星《传承-太平洋影音45周年纪念版 (CD2)》[FLAC/分轨][293.29MB]
- 首首经典《滚石红人堂I 一人一首成名曲 4CD》[WAV+CUE][2.5G]
- s14上单t0梯度怎么排名 s14世界赛上单t0梯度排行榜
- tes目前进了几次s赛 LPL队伍tes参加全球总决赛次数总览
- 英雄联盟巅峰礼赠什么时候开始 2024巅峰礼赠活动时间介绍
- 冯骥发文谈睡觉重要性 网友打趣:求求你先做DLC
- 博主惊叹《少女前线2》万圣节大雷皮肤:这真能过审吗?
- 《生化危机8》夫人比基尼Mod再引骂战:夸张身材有错吗?
- 江蕙.1994-悲情歌声【点将】【WAV+CUE】
- 戴娆.2006-绽放【易柏文化】【WAV+CUE】