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,在脚本后续想使用这些值时用${variable name}引用,例如用${name_1}即可使用"Tom"这个值。
以上便是JMeter操作mysql数据库的常规用法,已经能满足大部分使用情况,毕竟测试中一般只会进行查库操作,很少写库。但有时候我们难免遇到一次性执行多种类型sql语句(类似事务)的场景,按照上文中的写法,是实现不了的。
要实现这个功能,有两种方案,首先看方案一。
- 【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;
3、然后,【JDBC】中【Query Type】同样选择Callable Statement,sql语句只写上调用存储过程的语句即可。

运行脚本,查看结果,可以看到存储过程已经被执行,数据库数据被修改成功:

至此,JMeter操作mysql数据库的部分完结。
相关推荐
-
MySQL 由于 Java 日期 LocalDateTime 数据精度引发的线上问题
MySQL 由于 Java 日期 LocalDateTime 数据精度引发的线上问题2025-04-02 00:59:31 -
MySQL最常用分组聚合函数2025-04-02 00:55:56
-
NGINX: 轮询调度、加权轮询调度、平滑加权轮询调度2025-04-02 00:55:49
-
在Windows平台上安装Nginx并设置开机自动启动服务2025-04-02 00:47:04
-
PHP判断文件或者目录是否可写,兼容windows/linux系统
PHP判断文件或者目录是否可写,兼容windows/linux系统2025-04-02 00:27:54