Python接口自动化浅析pymysql数据库操作流程

本文主要介绍pymysql安装、操作流程、语法基础及封装操作数据库类,需要的朋友可以参考下,希望能对大家有所帮助,每日提升一点点,欢迎大家多多交流讨论

在自动化过程中,我们需要查询数据库,校验结果是否正确,比如充值完成之后,需要查询数据库,查看充值是否成功。

以下主要介绍,pymysql安装、操作流程、语法基础及封装操作数据库类。

一、pymysql介绍及安装

01 pymysql介绍

MySQL应该说是如今使用最为普遍的数据库了,没有之一,而Python作为最为流行的语言之一,自然少不了与MySQL打交道,其中PyMySQL就是使用最多的工具库。

  • PyMySQL是一个纯Python写的MySQL客户端,可以在CPython、PyPy、IronPython和Jython环境下运行;

  • PyMySQL的性能和MySQLdb几乎相当,如果对性能要求 不是特别的强,使用PyMySQL将更加方便;

  • PyMySQL的使用方法和MySQLdb几乎一样;

02 pymysql安装

方式一:使用命令安装

pip install pymysql

方式二:PyCharm内部安装

导入模块:

import pymysql

二、pymysql流程及模块说明

01 pymysql操作流程
  • 导入pymysql;

  • 建立数据库连接:使用pymysql的connect()方法连接数据,返回连接对象;

  • 使用连接对象创建游标对象(用于操作sql);

  • 准备写sql语句(select * from student);

  • 使用游标对象执行sql;

  • 查询数据使用游标获取;

  • 关闭游标(先)和数据库连接(后)。

02 pymysql模块说明

Connection对象

表示:conn=connect(参数列表)

作用:用于建立与数据库的连接;

创建对象:调用connect()方法;

参数列表:

host:连接的mysql主机,如本机是'localhost';

port:连接的mysql主机的端口,默认是3306;

database:数据库的名称;

user:连接的用户名;

password:连接的密码;

charset:通信采用的编码方式,推荐使用utf8;

对象的方法

对象方法如下:

close():关闭连接;

commit():提交;

cursor():返回Cursor对象,用于执行sql语句并获得结果;

execute(operation [, parameters ]):执行语句,返回受影响的行数,主要用于执行insert、update、delete语句,也可以执行create、alter、drop等语句;

fetchone():执行查询语句时,获取查询结果集的第一个行数据,返回一个元组;

fetchall():执行查询时,获取结果集的所有行,一行构成一个元组,再将这些元组装入一个元组返回;

关于pymysql防注入,字符串拼接查询,容易造成注入,为了避免注入,使用pymysql提供的参数化语句;

Cursor对象

游标(cursor)就是游动的标识,通俗的说,一条sql取出对应n条结果资源的接口/句柄,就是游标,沿着游标可以一次取出一行。

  • 用于执行sql语句,使用频度最高的语句为select、insert、update、delete;

  • 获取Cursor对象:调用Connection对象的cursor()方法:cs1=conn.cursor()

对象的属性
  • rowcount只读属性,表示最近一次execute()执行后受影响的行数;

  • connection获得当前连接对象;

三、pymysql语法基础

01 代码示例
  1. import pymysql

  2. # 连接数据库

  3. conn = pymysql.connect(host='127.0.0.1', user='ITester', password='123456',

  4. database='ITester', charset='utf8')

  5. # 创建游标

  6. cursor = conn.cursor()

  7. # 执行sql语句

  8. sql = 'select * from user limit 3;'

  9. res = cursor.execute(sql)

  10. # 获取查询结果的1条数据

  11. data = cursor.fetchone()

  12. print(data)

  13. # 关闭游标连接

  14. cursor.close()

  15. # 关闭数据库连接

  16. conn.close()

02 语法总结

1.连接数据库,需要host、user、password、database、charset等信息;

2.操作数据库先创建游标;

3.执行指定的sql语句,如果涉及到增、删、改数据库必须要conn.commit(),提交事务

4.查询获取数据条数有三种方法fetchone、fetchmany、fetchall。

  • cursor.fetchone() :默认获取查询结果的第一条数据;

  • cursor.fetchmany(2) :获取查询结果的指定条数,比如获取2条数据;

  • cursor.fetchall() :获取查询结果的所有数据;

5.需要注意的是,fetch获取的数据默认是元组,如果想要字典类型,

cursor=pymysql.cursors.DictCursor;

6.先关闭游标,后关闭数据库连接;

四、封装数据库类

01 封装说明

在实际项目中,很多地方都有用到数据库的操作,所以需要将数据库相关操作进行封装,方便其他模块调用。

如下,在common目录下,新建文件db_handler.py 用于封装数据库操作。

db_handler.py

  1. import pymysql

  2. class DBHandler:

  3. def __init__(self,host,port,user,password,

  4. database,charset,**kwargs):

  5. # 连接数据库服务器

  6. self.conn = pymysql.connect(host=host, port=port, user=user,password=password,

  7. database=database,cursorclass=pymysql.cursors.DictCursor,

  8. charset=charset,**kwargs)

  9. # 获取游标

  10. self.cursor = self.conn.cursor()

  11. def query(self, sql, args=None,one=True):

  12. self.cursor.execute(sql, args)

  13. # 提交事务

  14. self.conn.commit()

  15. if one:

  16. return self.cursor.fetchone()

  17. else:

  18. return self.cursor.fetchall()

  19. def close(self):

  20. self.cursor.close()

  21. self.conn.close()

  22. if __name__ == "__main__":

  23. db = DBHandler(host='127.0.0.1', port=3306,

  24. user='ITester', password='123456',

  25. database='ITester', charset='utf8')

  26. sql = 'select * from user limit 1;'

  27. data = db.query(sql)

  28. print(data)

以上就是Python接口自动化浅析pymysql数据库操作流程的详细内容。

感谢每一个认真阅读我文章的人,礼尚往来总是要有的,虽然不是什么很值钱的东西,如果你用得到的话可以直接拿走:

这些资料,对于【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴上万个测试工程师们走过最艰难的路程,希望也能帮助到你!有需要的小伙伴可以点击下方小卡片领取

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/1124222.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

基于python和flask框架的避暑山庄数字博物馆_5rb4d40z

目录避暑山庄数字博物馆系统概述核心功能模块技术实现特点创新与扩展性关于博主开发技术路线相关技术介绍核心代码参考示例结论源码lw获取/同行可拿货,招校园代理 :文章底部获取博主联系方式!避暑山庄数字博物馆系统概述 该系统基于Python和Flask框架开…

AI智能体(Agent)全解析:从技术原理到实战应用,程序员必学收藏的下一代生产力革命

AI智能体(AI Agent)是融合感知-决策-行动循环的AI系统,正引领工作方式变革。以LLM为"大脑"的AI Agent能自主完成复杂任务,从规划旅行到分析财报。技术虽面临幻觉、算力消耗等挑战,但市场增速迅猛,预计2030年达471亿美元…

Flutter 与原生通信机制全解析:MethodChannel / EventChannel / BasicMessageChannel,一篇讲透(工程级)

在 Flutter 项目中,只要涉及 系统能力、硬件设备、第三方 SDK、音视频、蓝牙、串口、机器人控制,就绕不开一个核心问题: 👉 Flutter 如何与 Android / iOS 原生通信?Flutter 官方提供了三种 Platform Channel&#xff…

Jmeter SQLite-DDT数据驱动/保存响应

1、下载数据驱动 SQLite的jar包,放到Jmeter的lib文件夹,重启Jmeter 2、创建连接 pool:-线程池必填 url: jdbc:sqlite:自定义一个dbfile文件名.db class: org.sqlite.JDBC user\password:不需要填写 附上MySQL的: 3、创建SQLi…

Flutter 逆向想学却无从下手?

2026 我和 Lane 联合出品硬核课程来了!Flutter 运行原理与Blutter项目解析各种python脚本以及实现原理分享内存 Dump 大量实战 Hook丰富案例 flutter-reverse项目实战不止 Flutter,后续还会分享更多案例demo全是真刀真枪的干货!私信主页 V …

基于python和flask加油站管理系统的设计与实现_33mc5571

目录加油站管理系统设计背景系统架构与技术栈核心功能模块关键技术实现系统测试与效果关于博主开发技术路线相关技术介绍核心代码参考示例结论源码lw获取/同行可拿货,招校园代理 :文章底部获取博主联系方式!加油站管理系统设计背景 随着燃油需求的增长和…

太流批了,有用的办公神器

今天给大家介绍一个非常好用的excel表格拆分和合并软件,这款软件可以将两个excel表格合并成一个,或者将一个excel表格拆分成多个。有需要的小伙伴可以下载收藏。 excel合并拆分工具 无限使用 软件无需安装,下载后解压即可,直接双…

牛批了,视频转换神器,办公必备

今天给大家介绍一款不错的视频转GIF动图的软件,软件功能非常强大,完全免费,有需要的小伙伴可以下载收藏。 V2GIF 视频转GIF工具 这款软件是绿色版,下载后解压双击打开就能直接使用了。 软件的主要特点: 1、不卡顿&a…

基于python和flask框架的医疗问诊拿药系统_01f8d3kp

目录 基于Python和Flask框架的医疗问诊拿药系统 关于博主开发技术路线相关技术介绍核心代码参考示例结论源码lw获取/同行可拿货,招校园代理 :文章底部获取博主联系方式! 基于Python和Flask框架的医疗问诊拿药系统 该系统采用Python语言与Flask轻量级框架…

基于SpringBoot的智能旅游行程规划系统的设计与实现

背景分析随着旅游业的快速发展和个性化需求的增长,传统旅游行程规划方式存在信息碎片化、效率低下等问题。游客需要手动整合交通、住宿、景点等数据,耗时且难以优化。SpringBoot作为轻量级Java框架,具备快速开发、微服务支持等优势&#xff0…

华为多款新品亮相 鸿蒙生态设备数量已超8亿台

鸿蒙开发语言arkts 昨日,华为举办夏季全场景新品发布会,华为常务董事、终端BG董事长、智能汽车解决方案BU董事长余承东表示,目前鸿蒙生态设备数量超8亿,短短一个月HarmonyOS4.2已升级用户超2000万,用户满意度提升11%&a…

深度测评MBA必备AI论文写作软件TOP8:开题报告文献综述全攻略

深度测评MBA必备AI论文写作软件TOP8:开题报告文献综述全攻略 MBA论文写作工具的测评价值与评测维度解析 随着人工智能技术在学术领域的广泛应用,越来越多的MBA学生开始借助AI论文写作软件提升研究效率。然而,面对市场上种类繁多的工具&#x…

推荐3个实用地理AI项目:MGeo支持网站链接数据抓取后清洗

推荐3个实用地理AI项目:MGeo支持网站链接数据抓取后清洗 在构建城市大脑、智慧物流、本地生活服务等系统时,地址数据的标准化与实体对齐是绕不开的核心挑战。大量来自不同平台的地址信息存在表述差异、错别字、缩写不一致等问题,导致无法直接…

Linux中Centos和Ubuntu的区别!

Linux是一种免费使用和自由传播的类UNIX操作系统,拥有众多发行版本,其中最受欢迎的就是Centos和Ubuntu,各自具有独特的特点和优势,那么Linux中Centos和Ubuntu的区别是什么?具体请看下文。CentOS和Ubuntu都是流行的Linux发行版&am…

学霸同款8个AI论文网站,专科生轻松搞定毕业论文!

学霸同款8个AI论文网站,专科生轻松搞定毕业论文! AI 工具助力论文写作,专科生也能轻松应对 在当前的学术环境中,越来越多的学生开始借助 AI 工具来提升论文写作效率。对于专科生而言,撰写毕业论文常常是学习生涯中的一…

BLE 4.2 Controller:高精度调度器与冲突仲裁

由于芯片通常只有一个 Radio(单射频),我们不能同时进行广播、扫描和保持连接。如果我在 37 信道广播时,连接的锚点(Anchor Point)也到了,该怎么办?如果我正在扫描,突然需…

Cloudera CDH5、CDH6、CDP7现状及替代方案

Cloudera CDH5、CDH6、CDP7现状及替代方案Cloudera 的 CDH5、CDH6 和 CDP7 系列产品已处于生命周期末期或战略转型阶段,其现状与替代路径对仍在使用这些平台的企业具有重大影响。以下从产品现状、停服时间线、风险分析及主流替代方案四个方面进行系统梳理。一、各版…

基于python和flask框架的汽车零件运输管理信息系统设计及实现_3xy1sjvu

目录摘要关于博主开发技术路线相关技术介绍核心代码参考示例结论源码lw获取/同行可拿货,招校园代理 :文章底部获取博主联系方式!摘要 该系统基于Python和Flask框架开发,旨在优化汽车零件运输管理流程,提升物流效率与数据透明度。…

网络安全攻防演练分为哪几步?

攻防演练是网络安全领域中的重要环节,而且开展一场攻防演练是一项复杂且重要的任务,它旨在检验和提升组织在面对真实网络攻击时的防护、检测、响应和恢复能力,那么网络安全攻防演练有几个步骤?我们一起来探讨一下吧。 攻防演练是一种模拟性质…

综合能源系统优化调度:基于MATLAB与CPLEX+Yalmip的创新实践

MATLAB程序:综合能源系统优化调度,考虑了阶梯型碳机制和氢能,具有一定的创新。 采用CPLEXYalmip求解,基本复现。在能源领域不断探索的道路上,综合能源系统优化调度成为了研究的热点。最近我在研究中实现了一个颇为有趣…