JMeter对数据库的查询操作步骤详解

提示:

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

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

JMeter中查询语句的操作步骤:

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

1、使用“用户自定义变量”实现参数化

即:在SQL Query使用参数化变量。

在JMeter中,有两个地方可以设置“用户自定义变量”。

一种是“测试计划”界面中设置“用户自定义变量”。

一种是添加配置元件中的“用户自定义变量”。

我们以“测试计划”为例。如下图:

(1)在“测试计划”界面中设置“用户自定义变量”。

我们添加了一个自定义变量用户ID,如下图:

(2)在JDBC Request界面的SQL Query中,使用${变量名}的方式进行引用。

  1. 我们在Varíable Name填写对应的数据库配置名称,与JDBC Connection Configuration组件中的Varíable Name对应。
  2. Query Type:选择Select Statement,因为我们只进行一条查询的SQL语句。
  3. 编写SQL语句,并使用${变量名}方式引用参数化变量。

如下图所示:

2、 在SQL Query中使用占位符传递参数

传递的参数值有常量和变量之分。

(1)传递的参数值是常量

传递2个常量:用户ID=3,用户名=孙悟空。

需要注意:

  1. 如果我们需要发送带有占位符的SQL语句,Query Type:需要选择Prepared Select Statement
  2. Parameter values参数值和Parameter types参数类型,都必须要填写(参数类型与表设计结构中的类型一致即可)。如果有多个占位符,就需要有多组数据,之间用逗号分隔。
  3. 发送SQL请求时,第一个参数会自动赋值给第一个占位符,以此类推,注意参数的编写顺序。

如下图所示:

(2)传递的参数值是变量

也就是占位符所接收的参数是一个参数化变量。我们把对应常量的位置,变成参数化变量即可,其他同上。

如下图所示:

各种形式的参数化可以这样使用。关于参数化相关知识,前面文章有详细说明。

3、Variables names参数的使用方法

Variables names参数的作用是,把SQL语句查询出来的数据保存到变量中。一般查询返回几个字段,就用几个变量来进行接收,不同的变量之间用逗号隔开。

JMeter官网给的解释是:如果给这个参数设置了值,它会保存SQL语句返回的数据和返回数据的总行数。

假如,SQL语句返回2行,3列的数据,且Variables names中设置为A,B,C,那么如下变量会被设置为:

A_#=2     # A列的总行数
A_1=3     # A列的第一个数据,也就是第1列, 第1行的数据
A_2=4     # A列的第二个数据,也就是第1列, 第2行的数据
B_#=2     # B列的总行数
B_1=sunwukong@1268.com    # B列的第一个数据,也就是第2列, 第1行的数据
B_2=zhubajie@1268.com     # B列的第二个数据,也就是第2列, 第2行的数据
C_#=2     # C列的总行数
C_1=孙悟空    # C列的第一个数据,也就是第3列, 第1行的数据
C_2=猪八戒    # C列的第二个数据,也就是第3列, 第2行的数据

说明:

如果返回结果为0,那么A_#C_#会被设置为0,其它变量不会设置值。

如果第一次请求返回6行数据,第二次请求只返回3行数据,那么第一次那多的3行数据,在线程变量中会被清除。

可以使用${A_#}${A_1}来获取相应的值,作为参数化数据进行传递。

可以添加Debug Sampler组件,来查看参数是否获取到了。

示例:

(1)JDBC Request组件界面内容

Variable names中定义接收数据的变量名,多个变量名之间用逗号分隔。

如下图所示:

(2)查看结果

添加一个取样器Debug Sampler用来查看输出的结果。(Debug Sampler组件可以查看到JMeter脚本运行中所有的变量)

JDBC Request请求结果,如下图所示:

查看Debug Sampler中的输出结果,如下图所示:

我们从上图中可以看到,JMeter把从数据库中查询出来的数据,存储在线程变量中了。

提示:

A代表第一列所有的数据,A_#可以获取到第一列的行数。A_n可以获得第一列第n行的数据。BC的功能类似, 假如我们只需要第一列和第三列的数据,可以写成A,,C,中间的,不可以省略。

4、Result variable name参数使用方法

如果给这个参数设置值,它会创建一个对象变量,保存所有返回的结果。

示例:

(1)JDBC Request组件界面内容

Result variable name中定义接收数据的变量名。

如下图所示:

(2)查看结果

添加一个取样器Debug Sampler用来查看输出的结果。(Debug Sampler组件可以查看到JMeter脚本运行中所有的变量)

JDBC Request请求结果,如下图所示:

查看Debug Sampler中的输出结果,如下图所示:

(3)数据处理

上面查看到的结果集,我们如何应用里面的数据呢?

我们可以创建一个BeanShell取样器,也可以在JDBC Request取样器下一级添加后置处理器BeanShell PostProcessor组件。

在里边编写如下代码,来获取需要的指定数据,提供给后面的接口请求使用。

对象中具体数据的获取方法:columnValue = vars.getObject("resultObject").get(0).get("Column Name")

5、总结:

以上我们就把Parameter valuesParameter typesVariable namesResult variable name的使用方式进行了说明。

在日常工作中,可以举一反三,灵活使用。

6、注意事项:

(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

参考:https://www.cnblogs.com/linbo3168/p/6039489.html

以上就是JMeter对数据库的查询操作 的详细内容,更多关于JMeter数据库操作 的资料请关注我们其它相关文章!

(0)

相关推荐

  • Jmeter连接数据库过程图解

    1.下载MySQL的jdbc驱动(mysql-connector-java-5.1.28.jar),将其放到 ...\apache-jmeter-3.3\lib\ 目录下 驱动下载地址:https://dev.mysql.com/downloads/connector/j/ 2.在测试计划下添加驱动地址 3.选择线程组-添加-配置原件-JDBC Connection Configuration 4.配置JDBC Connection Configuration Variable Name:该名称

  • Jmeter连接Mysql数据库实现过程详解

    昨天把Mysql装好了,这个躺在草稿中很久的文章也可以出炉了. 首先需要准备个Mysql jdbc驱动包,尽量保证其版本和你的数据库版本一致,至少不低于数据库版本,否则可能有问题.去官网扒一个下来吧:https://dev.mysql.com/downloads/connector/j/ 1.测试计划(Test Plan)下面把jdbc驱动包导入. 2.线程组下添加一个配置元件JDBC Connection Configuration. Variable Name:自定义参数,在JDBC Req

  • Jmeter基于JDBC请求实现MySQL数据库测试

    理论知识部分: 一.简单总结几点数据库测试点: 1.检查接口返回的数据是否与预期一致 2.传递数据类型错误时能否处理,比如数据类型要求是整数,传递小数时能否处理 3.接口参数的边界值 4.接口处理数据的时间 5.接口的安全性 二.Jemeter工具相关的设置: 第一步:打开jemeter,添加线程组 第二步:添加JDBC请求 增删改查不同的操作需调整SQL Query的Query Type (select statement 查询 Update statement 增删改 Callable st

  • python软件测试Jmeter性能测试JDBC Request(结合数据库)的使用详解

    JDBC Request 这个 Sampler 可以向数据库发送一个 jdbc 请求(sql 语句),并获取返回的数据库数据进行操作.它 经常需要和 JDBC Connection Configuration 配置原件(配置数据库连接的相关属性,如连接名.密码 等)一起使用. 1.本文使用的是 mysql 数据库进行测试 数据库的用户名为 root,用户名密码为 *********(看个人数据库用户名和密码填写) 2.数据库中有表:test,表的数据结构如下: 表中数据如下: select *

  • JMeter对数据库的查询操作步骤详解

    提示: 关于JMeter如何连接MySQL数据库,前面文章已经详解的讲解过了.因为配置数据库连接是比较固定的步骤,这里就不重复讲解了. 本篇文章主要详细说明,使用JDBC Request组件,如何对数据库进行查询的各种操作. JMeter中查询语句的操作步骤: 添加测试计划. 添加线程组,设置线程组的次数. 添加JDBC Connection Configuration组件,配置数据库连接. 添加JDBC Request请求,编写SQL语句,使用参数化.运行脚本,发送SQL请求. 添加察看结果树

  • MongoDB模糊查询操作案例详解(类关系型数据库的 like 和 not like)

    1.作用与语法描述 作用: 正则表达式是使用指定字符串来描述.匹配一系列符合某个句法规则的字符串.许多程序设计语言都支持利用正则表达式进行字符串操作.MongoDB 使用 $regex 操作符来设置匹配字符串的正则表达式. 语法一 { <field>: { $regex: /pattern/, $options: '<options>' } } { <field>: { $regex: 'pattern', $options: '<options>' } }

  • Mybatis中的resultType和resultMap查询操作实例详解

    resultType和resultMap只能有一个成立,resultType是直接表示返回类型的,而resultMap则是对外部ResultMap的引用,resultMap解决复杂查询是的映射问题.比如:列名和对象属性名不一致时可以使用resultMap来配置:还有查询的对象中包含其他的对象等. MyBatisConfig.xml <?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE configura

  • 树莓派3B+安装64位ubuntu系统和docker工具的操作步骤详解

    想在树莓派3B上安装一些64位应用(例如64位JDK),因此首先要安装64位的操作系统,今天咱们就一起来实战: 原文地址:https://blog.csdn.net/boling_cavalry/article/details/80716098 环境要求一台树莓派3B设备:网络环境是内网,需要有线网络和网线一根:当树莓派通过网线连接到内网后,能够在路由器管理软件上查到树莓派的IP,例如我用的是小米路由器,通过路由器管理页面或者小米路由器的APP就能看到树莓派的接入情况:读卡器:电脑一台,系统是w

  • Spring Cloud Eureka 注册与发现操作步骤详解

    在搭建Spring Cloud Eureka环境前先要了解整个架构的组成,常用的基础模式如下图: 服务提供者:将springboot服务编写好以后,通过配置注册中心地址方式注册,提供给消费者使用. 注册中心:服务的中间桥梁,服务提供者将服务注册.服务消费者可以通过注册信息调用需要使用的服务. 服务消费者:通过规定的调用方式,读取注册中心的注册信息,调用相应的服务. 根据后续的服务复杂度进化以后,可以看到服务提供者也可以是服务消费者,服务消费者也可以是服务提供者.根据不同的业务情况是可以互相调用的

  • MySQL数据库子查询语法规则详解

    目录 子查询简介 WHERE 子查询 FROM 子查询 SELECT 子查询 子查询是在查询语句里面再嵌套一个查询,这是因为我们在提取数据的时候有很多不知道的数据产生了依赖关系.此时我们就需要先查询一组数据的结果集,然后将这个结果集作用为下一个查询的对象.在 “表连接的章节”,我们曾说过子查询的效率低下的问题,其实并不是所有的子查询效率都是低下的,“WHERE” 子查询在匹配记录的时候要反复执行,这是不推荐使用的:但是如果将查询结果集当做一张表来使用,与其他的表做一个连接,这就是 “FROM”

  • MongoDB多表关联查询操作实例详解

    本文实例讲述了MongoDB多表关联查询操作.分享给大家供大家参考,具体如下: Mongoose的多表关联查询 首先,我们回忆一下,MySQL多表关联查询的语句: student表: calss表: 通过student的classId关联进行查询学生名称,班级的数据: SELECT student.name,student.age,class.name FROM student,class WHERE student.classId = class.id Mongoose多表联合查询(还是以众所

  • MySQL使用集合函数进行查询操作实例详解

    本文实例讲述了MySQL使用集合函数进行查询操作.分享给大家供大家参考,具体如下: COUNT函数 SELECT COUNT(*) AS cust_num from customers; SELECT COUNT(c_email) AS email_num FROM customers; SELECT o_num, COUNT(f_id) FROM orderitems GROUP BY o_num; SUM函数 SELECT SUM(quantity) AS items_total FROM

  • MySQL子查询操作实例详解

    本文实例总结了MySQL子查询操作.分享给大家供大家参考,具体如下: 定义两个表tb1和tb2 CREATE table tbl1 ( num1 INT NOT NULL); CREATE table tbl2 ( num2 INT NOT NULL); 向两个表中插入数据: INSERT INTO tbl1 values(1), (5), (13), (27); INSERT INTO tbl2 values(6), (14), (11), (20); any some关键字的子查询 SELE

  • MySQL单表查询操作实例详解【语法、约束、分组、聚合、过滤、排序等】

    本文实例讲述了MySQL单表查询操作.分享给大家供大家参考,具体如下: 语法 一.单表查询的语法 SELECT 字段1,字段2... FROM 表名                   WHERE 条件                   GROUP BY field                   HAVING 筛选                   ORDER BY field                   LIMIT 限制条数 二.关键字的执行优先级(重点) 重点中的重点:关键

随机推荐