JMeter操作Mysql数据库

JMeter连接mysql数据库是很方便的,下面就演示一下具体的操作。
首先,在本地安装好mysql服务器,建立库和表,并准备数据以供测试使用。在这里插入图片描述
接下来,在【测试计划】中添加JDBC驱动,即下载mysql-connector-bin.jar并添加到classpath中。如下图所示:在这里插入图片描述
当然,如果将这个jar包直接放在JMeter安装目录的lib文件夹中,就无需在【测试计划】中添加了。
当上面的准备工作完成后,就可以在线程组下添加一个【配置元件】–【JDBC Connection Configuration】
在这里插入图片描述
参数详解:在这里插入图片描述
添加【JDBC Request】在这里插入图片描述
最终脚本结构完成,运行脚本,结果如下:在这里插入图片描述
再看Debug Sampler中:在这里插入图片描述
可以看到,sql查询结果存储在变量中,例如name的变量,name_#=3,表示sql语句name字段有3个结果,name_1、name_2、name_3,在脚本后续想使用这些值时用 v a r i a b l e n a m e 引 用 , 例 如 用 {variable name}引用,例如用 variablename{name_1}即可使用"Tom"这个值。
以上便是JMeter操作mysql数据库的常规用法,已经能满足大部分使用情况,毕竟测试中一般只会进行查库操作,很少写库。但有时候我们难免遇到一次性执行多种类型sql语句(类似事务)的场景,按照上文中的写法,是实现不了的。
要实现这个功能,有两种方案,首先看方案一。

【JDBC Connection Configuration】配置页面,Database URL:jdbc:mysql://localhost:3306/hkkTest后添加?allowMultiQueries=true在这里插入图片描述
【JDBC Request】的【Query Type】选择Callable Statement,然后将多条sql语句按顺序写好,每条语句要以分号结尾。在这里插入图片描述
运行后,查看结果:在这里插入图片描述
再说方案二。
方案二使用的前提是,mysql服务器上已经建好相应的存储过程并执行,如下例:

delimiter $$;

存储过程后面必须有()

CREATE PROCEDURE user_procedure()

BEGIN

UPDATE test.user SET age=24 WHERE name=‘Tom’;

INSERT INTO test.user(id,name,age,address) VALUES(4,‘Lucy’,17,‘Paris’);

INSERT INTO test.user(id,name,age,address) VALUES(5,‘Messi’,32,‘Barcelona’);

DELETE FROM test.user WHERE name=‘Jack’;

SELECT * FROM test.user;

END

$$;delimiter;

3.然后,【JDBC】中【Query Type】同样选择Callable Statement,sql语句只写上调用存储过程的语句即可。在这里插入图片描述
运行脚本,查看结果,可以看到存储过程已经被执行,数据库数据被修改成功:在这里插入图片描述
至此,JMeter操作mysql数据库的部分完结。

最后我也整理了一些软件测试学习资料,对于学软件测试的小伙伴来说应该会很有帮助。有需要资料的朋友可以关注公众号:软件测试小dao,免费获取!包括,软件学习路线图,50多天的上课视频、16个突击实战项目,80余个软件测试用软件,37份测试文档,70个软件测试相关问题,40篇测试经验级文章,上千份测试真题分享,还有2021软件测试面试宝典,还有软件测试求职的各类精选简历,希望对大家有所帮助……

学习不要孤军奋战,最好是能抱团取暖,相互成就一起成长,群众效应的效果是非常强大的,大家一起学习,一起打卡,会更有学习动力,也更能坚持下去。

敲字不易,如果此文章对你有帮助的话,点个赞收个藏,给作者一个鼓励。也方便你下次能够快速查找。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值