提示

关于JMeter如何连接MySQL数据库,前面文章已经详解的讲解过了。因为配置数据库连是比较固定的步骤,这里就不重复讲解了。

本篇文章主要详细说明,使用JDBC Request组件,如何对数据库进行更新的各种操作。

JMeter中更新语句的操作步骤:

  1. 添加测试计划。
  2. 添加线程组,设置线程组的次数。
  3. 添加JDBC Connection Configuration组件,配置数据库连接。
  4. 添加JDBC Request请求,编写SQL语句,进行参数化。
  5. 运行脚本,发送SQL请求。
  6. 添加察看结果树,查看结果。

说明:更新操作包含insertupdatedelete三种操作,都是一样性质的,所以我们就以insert操作为例进行说明。

1、执行一条insert语句

使用JMeter发送一条insert语句非常的简单。

JDBC Request组件中做如下操作:

  1. 选择数据库连接配置。
  2. 选择Query Type:因为是执行一条insert语句,所以选择Update Statement即可。
  3. 把完整一条insert语句,输入到Query文本框中。

如下图所示:

说明:这是最基础的insert操作,发送了一条固定的insert请求。

2、insert语句实现参数化

JMeter中在insert请求中实现参数化也非常的简单。

JDBC Request组件中做如下操作:

  1. 选择数据库连接配置。
  2. 选择Query Type:因为是执行一条insert语句,所以选择Update Statement即可。
  3. 把完整一条insert语句,输入到Query文本框中。
  4. 把需要参数化的部分,替换成参数化变成的引用即可。

使用函数助手为例进行演示,如下图所示:

说明:其他形式的参数化也都可以,如利用CSV这个元件去做语句的参数化。本例中是用函数助手方便演示。

提示:如果有些字段是自增长的值或者是有默认值,那么就可以不写,让其自动填充。

3、一次执行多条insert语句

使用JMeter发送一次执行多条insert语句非常的简单,就是直接写入多条insert语句,之间用;分隔开。

JDBC Request组件中做如下操作:

  1. 选择数据库连接配置。
  2. Database URL 后增加一个参数allowMultiQueries=true,才可以执行多条SQL语句(重点)。
  3. 选择Query Type:我们可以选择Update StatementPrepared Update StatementCallable Statement,这三种类型语句都可以。

    选择Update Statement类型,执行一条insert语句发送一次请求。

    而选择Prepared Update StatementCallable Statement类型,则全程只发送一起请求。
  4. 把完整一条insert语句,输入到Query文本框中。

如下图所示:

4、使用Beanshell生成加密数据示例

我们在更新数据库的时候,有时候会有部分数据直接插入是不可以的,需要加密处理。

那么就可以使用BeanShell 取样器组件完成对数据的加密操作。

然后把加密好的数据,存储到JMeter的线程变量中,方便进一步的引用。

提示:加密代码,可以找开发要,也可以自己扒源码找。

JMeter中更新有加密数据的操作步骤:

  1. 添加测试计划。
  2. 添加线程组,设置线程组的次数。
  3. 添加JDBC Connection Configuration组件,配置数据库连接。
  4. 添加BeanShell 取样器组件,编写加密算法,并把加密的数据存储到线程变量中。
  5. 添加JDBC Request请求,编写SQL语句,使用参数化,并引用加密的线程变量。
  6. 运行脚本,发送SQL请求。
  7. 添加察看结果树,查看结果。

(1)测试计划内包含的元件

添加元件操作步骤

  1. 创建测试计划。
  2. 创建线程组:选中“测试计划”右键 —> 添加 —> 线程(用户) —> 线程组
  3. 在线程组下,添加配置原件JDBC连接配置组件:选中“线程组”右键 —> 添加 —> 配置元件 —> JDBC Connection Configuration
  4. 在线程组下,添加取样器BeanShell 取样器组件:选中“线程组”右键 —> 添加 —> 取样器 —> BeanShell 取样器
  5. 在线程组下,添加取样器JDBC Request组件:选中“线程组”右键 —> 添加 —> 取样器 —> JDBC Request
  6. 在线程组下,添加监听器“察看结果树”组件:选中“线程组”右键 —> 添加 —> 监听器 —> 察看结果树

最终测试计划中的元件如下:

点击运行按钮,会提示你先保存该脚本,脚本保存完成后会直接自动运行该脚本。

(2)JDBC连接配置组件内容

基本的JDBC连接配置,界面内容详解可以看前面的文章【JMeter连接数据库】。

主要是定义数据库连接池的名称,还有最下方关于数据库的基本信息配置。

如下图所示:

(3)BeanShell取样器界面内容

把生成加密内容的BeanShell代码,写入到界面的脚本输入框中。

如下图所示:

完整代码放在下面:

import java.io.PrintStream;
import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;
import java.util.Arrays; public class PWDEncryptionUtils { // 静态方法,类直接调用
// 对明文密码进行加密
public static String encryptPwd(String pwd) {
return stringMD5(pwd);
} public static String stringMD5(String input) {
try {
MessageDigest messageDigest = MessageDigest.getInstance("MD5");
byte[] inputByteArray = input.getBytes();
messageDigest.update(inputByteArray);
byte[] resultByteArray = messageDigest.digest();
return byteArrayToHex(resultByteArray);
} catch (NoSuchAlgorithmException localNoSuchAlgorithmException) {
localNoSuchAlgorithmException.printStackTrace();
}
return null;
} public static String byteArrayToHex(byte[] byteArray) {
char[] hexDigits = {'0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'A', 'B', 'C', 'D', 'E', 'F'};
char[] resultCharArray = new char[byteArray.length * 2];
int index = 0;
byte[] arrayofByte = byteArray;
int j = byteArray.length;
for (int i = 0; i < j; i++) {
byte b = arrayofByte[i];
resultCharArray[(index++)] = hexDigits[(b >>> 4 & 0xF)];
resultCharArray[(index++)] = hexDigits[(b & 0xF)];
}
return new String(resultCharArray);
} // public static void main(String[] args) {
// PWDEncryptionUtils test = new PWDEncryptionUtils();
// String result = test.encryptPwd("12345678");
// System.out.println("result = " + result);
// } } //调用执行步骤 // 1.创建实例
PWDEncryptionUtils test = new PWDEncryptionUtils(); // 2.调用加密函数
String pwd=test.encryptPwd("${__RandomString(8,0123456789,)}"); // 3.存储数据到JMeter线程变量中
vars.put("new_pwd",pwd);

说明一下:

  • 这里主要看最后的三行代码,使用函数助手生成的8位数字为数据,进行加密运算。
  • 然后存入到JMeter的线程变量中,变量名为new_pwd
  • 最后,后续的请求中可以引用该变量。

提示:在调试BeanShell代码的时候,可以添加Debug Sampler组件来查看获取结果。

如下图所示:

(4)JDBC Request组件中内容

填写应用的数据库连接池名称,然后编写insert语句,最后加入参数化和加密数据的引用。

我把加密后的数据放在了slogan字段中了,如下图所示:

(5)查看结果

我把线程组中的线程数设置为3,也就是执行三次该请求。

结果如下图所示,执行了三次SQL请求:

我们在去数据库中查看数据是否添加成功。

如下图所示,新增了三条数据,并且slogan字段中的数据是经过加密的。

以上就完整的实现了,把经过加密的数据,存储到数据库中的演示。

5、注意事项

(1)The server time zone value服务器时区异常

如果报错,如下:

Cannot create PoolableConnectionFactory (The server time zone value '???��������??��??' is unrecognized or represents more than one time zone. You must configure either the server or JDBC driver (via the serverTimezone configuration property) to use a more specifc time zone value if you want to utilize time zone support.)

解决方法:数据库连接URL后面加 serverTimezone=GMTserverTimezone=GMT%2B8,即可解决。

(2)执行多条SQL语句

执行多条SQL语句时,查询语句selectupdateinsert语句不能在同一个JDBC Request组件中执行。

当执行多条SQL 语句时,每条语句后面加;

并且在 Database URL 后增加一个参数allowMultiQueries=true,否则将不能够执行多条语句,报错。

(3)更新操作中文乱码

需要在 Database URL 后增加一个参数characterEncoding=utf-8,这样就可以解决更新操作时候的中文乱码了。

提示:一定要设置为UTF-8编码吗?不一定,要跟你的数据库的编码保持一致,就不会中文乱码了。

(4)Datebase URL添加参数规则

Datebase URL后增加参数,在dbname后加?,如有多个参数,每个参数用&隔开,如:

jdbc:mysql://127.0.0.1:3306/guest?serverTimezone=GMT&useUnicode=true&characterEncoding=utf-8&allowMultiQueries=true

『动善时』JMeter基础 — 44、JMeter对数据库的更新操作的更多相关文章

  1. 『动善时』JMeter基础 — 6、使用JMeter发送一个最基础的请求

    目录 步骤1:创建一个测试计划 步骤2:创建线程组 步骤3:创建取样器 步骤4:创建监听器 步骤5:完善信息 步骤6:保存测试计划 步骤7:查看结果 总结:JMeter测试计划要素 当我们第一次打开J ...

  2. 『动善时』JMeter基础 — 41、使用JMeter连接数据库(MySQL)

    目录 1.为什么要使用JMeter连接数据库 2.JMeter连接数据库的前提 3.JDBC连接配置组件界面介绍 4.JMeter连接数据库演示 (1)测试计划内包含的元件 (2)测试计划中添加链接数 ...

  3. 『动善时』JMeter基础 — 29、JMeter响应断言详解

    目录 1.JMeter断言介绍 2.响应断言组件界面详解 3.响应断言组件的使用 (1)测试计划内包含的元件 (2)登陆接口请求界面内容 (3)响应断言界面内容 (4)查看运行结果 (5)断言结果组件 ...

  4. 『动善时』JMeter基础 — 43、JMeter对数据库的查询操作

    目录 1.使用"用户自定义变量"实现参数化 2. 在SQL Query中使用占位符传递参数 (1)传递的参数值是常量 (2)传递的参数值是变量 3.Variables names参 ...

  5. 『动善时』JMeter基础 — 49、使用JMeter自身代理录制APP测试脚本

    目录 1.测试计划内包含的元件 2.HTTP代理服务器的设置内容 3.设置手机的代理服务器 4.录制脚本 5.查看录制的脚本 6.HTTP代理服务器的排除模式 7.保存脚本 8.注意坑点 录制脚本只不 ...

  6. 『动善时』JMeter基础 — 58、JMeter分布式测试

    目录 1.JMeter分布式测试概念 2.JMeter分布式测试前提条件 3.JMeter实现分布式测试 (1)在执行机中的配置 (2)在控制机中的配置 (3)启动执行机中的JMeter服务 (4)在 ...

  7. 『动善时』JMeter基础 — 61、使用JMeter监控服务器

    目录 1.监控插件安装 2.启动监控服务 3.使用JMeter监控服务器 (1)测试计划内包含的元件 (2)HTTP请求界面内容 (3)配置jp@gc-PerfMon Metrics Collecto ...

  8. 『动善时』JMeter基础 — 1、JMeter介绍

    1.什么是JMeter Apache JMeter是Apache组织开发的基于Java的压力测试工具,用于对软件做压力测试.它最初被设计用于Web应用测试,但后来扩展到其他测试领域. (Apache ...

  9. 『动善时』JMeter基础 — 3、JMeter插件管理

    JMeter是一个Java开发的开源软件,开源的软件有一个好处,就是会有很多第三方开发出来的插件,使得JMeter在处理某一些功能的时候更加的方便.并且这些插件拿过来就可以使用,完全免费的. 我们安装 ...

随机推荐

  1. Caddy-基于go的微型serve用来做反向代理和Gateway

    1.简单配置 2.go实现,直接一个二进制包,没依赖. 3.默认全站https 常用 反向代理,封装多端口gateway 使用:启动直接执行二进制文件 caddy 就行 根据输出信息 直接https: ...

  2. [CTF]URL编码

    [CTF]URL编码 ---------------------  作者:adversity`  来源:CSDN  原文:https://blog.csdn.net/qq_40836553/artic ...

  3. ResNet学习笔记

    ResNet学习笔记 前言 这篇文章实在看完很多博客之后写的,需要读者至少拥有一定的CNN知识,当然我也不知道需要读者有什么水平,所以可能对一些很入门的基本的术语进行部分的解释,也有可能很多复杂的术语 ...

  4. Day002 Java特性和优势

    Java特性和优势 简单性(摒弃了c++的指针和内存分配释放) 面向对象(万物皆对象) 可移植性(write once run anywhere) 高性能 分布式 动态性(反射机制) 多线程 安全性 ...

  5. Linux安装Redis报错`cc:命令未找到`

    缺少gcc和gcc-c++的编译环境,安装即可. 可以联网情况下使用命令 yum install gcc yum install gcc-c++ 然后清理原来的残余文件 make distclean ...

  6. v-for详解

    v-for的引入 当我们需要对一组数据进行渲染时,我们就可以使用v-for来完成 v-for遍历数组 格式:v-for="(item, index) in items".(也许是因 ...

  7. 带你解析MySQL binlog

    前言: 我们都知道,binlog可以说是MySQL中比较重要的日志了,在日常学习及运维过程中,也经常会遇到.不清楚你对binlog了解多少呢?本篇文章将从binlog作用.binlog相关参数.解析b ...

  8. JVM虚拟机 类加载过程与类加载器

    目录 前言 类的生命周期 类加载过程 加载 连接 验证 准备 解析 初始化 类加载器 三大类加载器 双亲委派模型 概念 为什么要使用双亲委派模型 源码分析 反双亲委派模型 参考 前言 类装载器子系统是 ...

  9. nano 按Ctrl+X 输入Y 回车

    如何退出nano 1.nano 按Ctrl+X 如果你修改了文件,下面会询问你是否需要保存修改. 2.输入Y确认保存,输入N不保存,按Ctrl+C取消返回.如果输入了Y,下一步会让你输入想要保存的文件 ...

  10. Centos7如何安装开源办公软件Libreoffice

    在Centos7安装了WPS,但是用了没两月就出问题,无法正常使用.(准确来说,安装的WPS一直都有各种问题存在,但是没有影响到主要功能也就将就着用,后来是直接输入不了文字) 既然是开源系统,自然而然 ...