用python实现接口测试(四、操作MySQL)

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: 一、MySQL简介使用Python进行MySQL的库主要有三个,Python-MySQL(更熟悉的名字可能是MySQLdb),PyMySQL和SQLAlchemy。

一、MySQL简介

使用Python进行MySQL的库主要有三个,Python-MySQL(更熟悉的名字可能是MySQLdb),PyMySQL和SQLAlchemy。

Python-MySQL资格最老,核心由C语言打造,接口精炼,性能最棒,缺点是环境依赖较多,安装复杂,近两年已停止更新,只支持Python2,不支持Python3。

PyMySQL为替代Python-MySQL而生,纯python打造,接口与Python-MySQL兼容,安装方便,支持Python3。

SQLAlchemy是一个ORM框架,它并不提供底层的数据库操作,而是要借助于MySQLdb、PyMySQL等第三方库来完成,目前SQLAlchemy在Web编程领域应用广泛。

二、MySQL安装方式

软件版本:

MYQSL:mysql-5.7.17

PYTHON:Python 3.4.4

1.电脑端的安装MYQSL来作为server:详情操作步骤见MySQL+Python 3.4.4MySQL图文安装教程

2.Python端安装pymysql,简单的命令安装方式:pip install pymysql

离线安装方式:下载MySQL安装包后执行命令pip install pymysql-x.x.x.tar.gz

img_d3abce3c97dacd81a77eda9412755e89.png
安装成功标志

三、数据库常用指令

1.Python下链接数据库的接口解析:

pymysql.Connect()参数说明

host(str):      MySQL服务器地址

port(int):      MySQL服务器端口号

user(str):      用户名

passwd(str):    密码

db(str):        数据库名称

charset(str):  连接编码

connection对象支持的方法

cursor()        使用该连接创建并返回游标

commit()        提交当前事务

rollback()      回滚当前事务

close()        关闭连接

cursor对象支持的方法

execute(op)    执行一个数据库的查询命令

fetchone()      取得结果集的下一行

fetchmany(size) 获取结果集的下几行

fetchall()      获取结果集中的所有行

rowcount()      返回数据条数或影响行数

close()        关闭游标对象

2.数据库游标对象cursor支持的方法:

img_ca43f5bfbd15cce271f64c459987f767.png
游标cursor方法

3.MySQL数据库常用指令:

show databases;      // 查看当前所有的数据库

create database user;   //创建user数据库

use test;     //作用与test数据库

show tables;    //查看test库下面的表

CREATE  TABLE  user (name VARCHAR(20),password VARCHAR(20));    //创建user表,name 和password 两个字段

insert into user values('Tom','1321');   //向user表内插入若干条数据

select * from user;      //查看user表的数据

delete from user where name = 'Jack';   //删除name 等于Jack的数据

update user set password='1111' where name = 'Alen';    //修改name等于Alen 的password 为 1111

 select * from user;    //查看表内容

四、MySQL操作指令之连接操作

pycharm+pymysql连接mysql之前先打开MySQL server服务端

img_fb18127e0ae8c5849f6312e3631c738c.png
MySQL server 5.7

连接操作需知道主机地址host、端口port、用户名user、用户密码password、数据库名和编码方式charset(编码方式可写可不写)

img_114bd08e524b81c636a3fcda102adff1.png
数据库连接操作

创建数据表

img_e44630a4fb8638fc396892305e937f1f.png
创建数据表

五、MySQL操作指令之插入操作

img_6f7d5308c6e8c9d2917968fd3d3214da.png
插入多条数据

六、MySQL操作指令之查询操作

img_0df18f7ab01317f191a1b9fda7573e93.png
查询数据操作

七、MySQL操作指令之更新操作

img_c9c845162d909eeb04156d1772b44239.png
更新数据操作

八、MySQL操作指令之删除操作

img_57cd116d1ee5c73eeaa3a05e52c0c473.png
删除操作

九、数据库代码重构

1.直接上代码---pymysql.py

#coding:utf-8

import pymysql

import config

import pymysql.cursors

class PyMySQLHelper(object):

def __init__(self):

self.conn = config.conn_dict

def get_one(self, sql, params):

conn = pymysql.connect(**self.conn)

cur = conn.cursor(cursor = pymysql.cursors.DictCursor)

retCount = cur.execute(sql, params)

data = cur.fetchone()

cur.close()

conn.close()

return data

def get_many(self, sql, params):

conn = pymysql.connect(**self.conn)

cur = conn.cursor(cursor = pymysql.cursors.DictCursor)

retCount = cur.execute(sql, params)

data = cur.fetchall()

cur.close()

conn.close()

return data

def insert_one(self, sql, params):

conn = pymysql.connect(**self.conn)

cur = conn.cursor()

cur.execute(sql, params)

conn.commit()

cur.close()

return u'插入数据库成功'

    def insert_many(self, sql, params):

conn = pymysql.connect(**self.conn)

cur = conn.cursor()

cur.executemany(sql, params)

conn.commit()

cur.close()

return u'批量插入数据库成功'

    def update_one(self, sql, params):

conn = pymysql.connect(**self.conn)

cur = conn.cursor(cursor = pymysql.cursors.DictCursor)

ret = cur.execute(sql, params)

conn.commit()

cur.close()

conn.close()

return u'更新数据库成功'

    def delete_one(self, sql, params):

conn = pymysql.connect(**self.conn)

cur = conn.cursor(cursor = pymysql.cursors.DictCursor)

ret = cur.execute(sql, params)

conn.commit()

cur.close()

conn.close()

return u'删除数据库成功'

class CheckUser(object):

def __init__(self):

self.__helper = PyMySQLHelper()

def checkValid(self, name, password):

sql ='select * from user where name=%s and password=%s'

        params = (name, password)

return self.__helper.get_one(sql, params)

def info():

name =raw_input(u'请输入你的用户名:')

password =raw_input(u'请输入你的密码:')

user = CheckUser()

result = user.checkValid(name, password)

if not result:

print u'用户名或者密码错误,请联系管理员'

    else:

print u'恭喜您,输入正确!'

if __name__ =='__main__':

info()

config.py

#coding:utf-8

conn_dict=dict(host='127.0.0.1', user='root', passwd='123456', db='user',charset='utf8')

2.查看数据库用户名称和密码

img_d6066a2edd68bbe8aeec9fa71d026851.png
user数据库中的用户名和密码

3.运行上述代码,输入user数据库中的用户名和密码进行测试

img_62daa9592b1679f0ce80b615bd55abca.png
运行结果

MySQL练习暂时告一段落,以上代码还需继续优化,不然每次操作数据库时不注销掉创建表格等操作的话会导致代码运行提示错误,后续继续优化代码。。。

相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
打赏
0
0
0
0
3
分享
相关文章
接口测试新选择:Postman替代方案全解析
在软件开发中,接口测试工具至关重要。Postman长期占据主导地位,但随着国产工具的崛起,越来越多开发者转向更适合中国市场的替代方案——Apifox。它不仅支持中英文切换、完全免费不限人数,还具备强大的可视化操作、自动生成文档和API调试功能,极大简化了开发流程。
除了postman还有什么接口测试工具
最好还是使用国内的接口测试软件,其实国内替换postman的软件有很多,这里我推荐使用yunedit-post这款接口测试工具来代替postman,因为它除了接口测试功能外,在动态参数的支持、后置处理执行sql语句等支持方面做得比较好。而且还有接口分享功能,可以生成接口文档给团队在线浏览。
56 2
大前端之前端开发接口测试工具postman的使用方法-简单get接口请求测试的使用方法-简单教学一看就会-以实际例子来说明-优雅草卓伊凡
大前端之前端开发接口测试工具postman的使用方法-简单get接口请求测试的使用方法-简单教学一看就会-以实际例子来说明-优雅草卓伊凡
121 10
大前端之前端开发接口测试工具postman的使用方法-简单get接口请求测试的使用方法-简单教学一看就会-以实际例子来说明-优雅草卓伊凡
使用崖山YMP 迁移 Oracle/MySQL 至YashanDB 23.2 验证测试
这篇文章是作者尚雷关于使用崖山YMP迁移Oracle/MySQL至YashanDB 23.2的验证测试分享。介绍了YMP的产品信息,包括架构、版本支持等,还详细阐述了外置库部署、YMP部署、访问YMP、数据源管理、任务管理(创建任务、迁移配置、离线迁移、校验初始化、一致性校验)及MySQL迁移的全过程。
以项目登录接口为例-大前端之开发postman请求接口带token的请求测试-前端开发必学之一-如果要学会联调接口而不是纯写静态前端页面-这个是必学-本文以优雅草蜻蜓Q系统API为实践来演示我们如何带token请求接口-优雅草卓伊凡
以项目登录接口为例-大前端之开发postman请求接口带token的请求测试-前端开发必学之一-如果要学会联调接口而不是纯写静态前端页面-这个是必学-本文以优雅草蜻蜓Q系统API为实践来演示我们如何带token请求接口-优雅草卓伊凡
93 5
以项目登录接口为例-大前端之开发postman请求接口带token的请求测试-前端开发必学之一-如果要学会联调接口而不是纯写静态前端页面-这个是必学-本文以优雅草蜻蜓Q系统API为实践来演示我们如何带token请求接口-优雅草卓伊凡
Python 高级编程与实战:构建自动化测试框架
本文深入探讨了Python中的自动化测试框架,包括unittest、pytest和nose2,并通过实战项目帮助读者掌握这些技术。文中详细介绍了各框架的基本用法和示例代码,助力开发者快速验证代码正确性,减少手动测试工作量。学习资源推荐包括Python官方文档及Real Python等网站。
Python测试淘宝店铺所有商品接口的详细指南
本文详细介绍如何使用Python测试淘宝店铺商品接口,涵盖环境搭建、API接入、签名生成、请求发送、数据解析与存储、异常处理等步骤。通过具体代码示例,帮助开发者轻松获取和分析淘宝店铺商品数据,适用于电商运营、市场分析等场景。遵守法规、注意调用频率限制及数据安全,确保应用的稳定性和合法性。
Socket.IO介绍,以及怎么连接测试Socket.IO接口?
Socket.IO 是一个用于浏览器和服务器间实时双向通信的库,支持低延迟消息传递、跨平台运行及自动重连。文章介绍了其特点与调试需求,并详细说明如何使用 Apifox 工具创建、连接、发送/接收 Socket.IO 事件,以及团队协作和调试技巧。掌握这些技能可提升实时应用开发效率与质量。
微信公众号接口测试实战指南
微信公众号接口测试是确保系统稳定性和功能完整性的重要环节。本文详细介绍了测试全流程,包括准备、工具选择(如Postman、JMeter)、用例设计与执行,以及常见问题的解决方法。通过全面测试,可以提前发现潜在问题,优化用户体验,确保公众号上线后稳定运行。内容涵盖基础接口、高级接口、微信支付和数据统计接口的测试,强调了功能验证、性能优化、安全保护及用户体验的重要性。未来,随着微信生态的发展,接口测试将面临更多挑战和机遇,如小程序融合、AI应用和国际化拓展。
Python中使用MySQL模糊查询的方法
本文介绍了两种使用Python进行MySQL模糊查询的方法:一是使用`pymysql`库,二是使用`mysql-connector-python`库。通过这两种方法,可以连接MySQL数据库并执行模糊查询。具体步骤包括安装库、配置数据库连接参数、编写SQL查询语句以及处理查询结果。文中详细展示了代码示例,并提供了注意事项,如替换数据库连接信息、正确使用通配符和关闭数据库连接等。确保在实际应用中注意SQL注入风险,使用参数化查询以保障安全性。
AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等