如何用JMeter操作Mysql数据库,简单搞定!

在接口测试中,尤其是场景串联的时候,常常需要与数据库进行交互,考虑到这一点,JMeter在操作mysql数据库方面提供了非常全面而便捷的解决方案。

演示所用JMeter版本为:5.4.1,JDBC版本为8.0.11

JDBC驱动安装

第一步,在【测试计划】中添加JDBC驱动,即下载mysql-connector-bin.jar(下载地址:https://downloads.mysql.com/archives/c-j/)并添加到classpath中,当然,如果将这个jar包直接放在JMeter安装目录的lib文件夹中,就无需在【测试计划】中添加了。如下图所示:

在这里插入图片描述

配置数据库连接

线程组下添加一个【配置元件】–>【JDBC Connection Configuration】,在这里填写连接信息:

在这里插入图片描述

关于这里面的参数,解释一下含义:

  1. Variable Name for created pool:连接所绑定的变量名。可以创建多个连接,每个连接绑定到不同的变量名,后续【JDBC Request】通过对应variable name使用相应的连接。
  2. Max Number of Connections:连接池最大允许连接数。默认设置为0,代表每个线程获得自己的连接池。如果使用共享连接池,将其设置成与线程数相同即可。
  3. Max Wait (ms):超时时间。如果尝试连接的过程超过了这个时间,则抛出异常并停止连接。
  4. Time Between Eviction Runs (ms):运行状态下,空闲对象回收线程休眠时间。如果设为负数,空闲对象回收线程将不会运行
  5. Auto Commit:自动提交开关,true代表开启。
  6. Transaction isolation:事务隔离,一般使用默认即可。
  7. Test While Idle | 当连接空闲时是否进行测试。
  8. Soft Min Evictable Idle Time(ms) :连接可以在池中处于空闲状态的最短时间,超过这个时间的空闲连接才会被回收。Validation Query | 用于确定数据库是否仍在响应的简单查询 | 否 |
  9. Database URL:数据库的JDBC连接串。
  10. Username:数据库连接的用户名。
  11. Password:数据库连接的密码。

Sql语句与结果提取

添加一个【JDBC Request】的取样器,填入数据源名称、SQL语句以及查询结果字段映射的变量名:

在这里插入图片描述

最终脚本结构完成,运行脚本,结果如下:

在这里插入图片描述

再看Debug Sampler中:

在这里插入图片描述

可以看到,sql查询结果存储在变量中,例如name的变量,goodsNo_#=3,表示sql语句返回三行结果,在后续想使用这些值时用${variable name}引用,例如用\${goodsNo_1}

以上便是JMeter操作mysql数据库的常规用法,已经能满足大部分使用情况,毕竟测试中一般只会进行查库操作,很少写库。

批量语句处理

但有时候我们难免遇到一次性执行多种类型sql语句(类似事务)的场景,按照上文中的写法,是实现不了的。

要实现这个功能,有两种方案,首先看方案一,就是支持批量提交:

  1. 【JDBC Connection Configuration】配置页面,Database URL:jdbc:mysql://localhost:3306/hkkTest后添加?allowMultiQueries=true
    在这里插入图片描述
  2. 【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;

然后,【JDBC】中【Query Type】同样选择Callable Statement,sql语句只写上调用存储过程的语句即可。
在这里插入图片描述

以上是JMeter操作mysql数据库的全部内容,整体来看是非常便捷的。

评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

云深i不知处

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值