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


Posted in Python onJanuary 26, 2021

JDBC Request

这个 Sampler 可以向数据库发送一个 jdbc 请求(sql 语句),并获取返回的数据库数据进行操作。它 经常需要和 JDBC Connection Configuration 配置原件(配置数据库连接的相关属性,如连接名、密码 等)一起使用。

1.本文使用的是 mysql 数据库进行测试

数据库的用户名为 root,用户名密码为 *********(看个人数据库用户名和密码填写)

2、数据库中有表:test,表的数据结构如下:

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

表中数据如下:
select * from test (不要添加分号作为结尾。)

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

3、添加需要的驱动 jar 包
使用不同的数据库,我们需要引入不同的 jar 包。

方式 1:直接将 jar 包复制到 jmeter 的 lib 目录
mysql 数据库:无需引入其他数据库驱动 jar 包。

sql server 数据库:下载 sqljdbc4.jar 放到 jmeter 根目录的 lib 目录下

oracle数据库:将oracle数据的安装目录下面的\product\10.2.0\db_1\jdbc\lib\ojdbc14.jar 放 到 jmeter 根目录下的 lib 目录下

方式 2:通过 Test Plan
假如我们不使用将 jar 复制到 jmeter 的 lib 目录的方式,我们还可以使用 Jmeter 的 Test Plan 引入 相应的 jar 包,如下面引入 oracle 数据的 jar 包。

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

二、配置 JDBC Connection Configuration

重要参数说明:
Variable Name:

数据库连接池的名称,我们可以有多个 jdbc connection configuration,每 个可以起个不同的名称,在 jdbc request 中可以通过这个名称选择合适的连接池进行使用。

Database URL:

数据库 url,jdbc:mysql://主机 ip 或者机器名称:mysql 监听的端口号/数据库 名称, 如:jdbc:mysql://localhost:3306/test

**JDBC Driver class:**JDBC 驱动

**username:**数据库登陆的用户名

**passwrod:**数据库登陆的密码

不同数据库具体的填写方式,可以参考下面的表格:

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

填写后大致如下:

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

三、配置 JDBC Request

重要的参数说明:

Variable Name:数据库连接池的名字,需要与 JDBC Connection Configuration 的 Variable Name Bound Pool 名字保持一致

Query:填写的 sql 语句未尾不要加“;”

Parameter valus:参数值

Parameter types:参数类型,可参考:Javadoc for java.sql.Types

Variable names:保存 sql 语句返回结果的变量名

Result variable name:创建一个对象变量,保存所有返回的结果

Query timeout:查询超时时间

Handle result set:定义如何处理由 callable statements 语句返回的结果

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

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

执行到这里,我们已经将数据从数据库中原样的查出来了,但具体如何之取出我们需要的数据呢,显然, 假如我们查询的 sql 返回的只是一个数据,上面的方式已经可以满足我们的需求的,如我们查询数据的记 录数,

select count(*) from test

查询出来的结果就是我们需要的内容,或者通过正则表达式的获取即可获取我们的内容。 但假如像上面那样子,我们获取出来的是多行数据,我们需要如何来对数据进行遍历,只获取出我们 需要的数据呢?请看下面的分析。

四、JDBC Request 参数化

方法(一)、定义变量,在 sql query 中使用变量:

1、在 Test Plan 中定义一个变量(当然也可以使用参数化:Jmeter 参数化):

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

2、sql query 中使用${变量名}的方式引用:

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

方法(二)、在 sql query 中使用”?“作为占位符,并传递参数值和参数类型,如下图所示:

1、传递的参数值是常量,如图传递 2 个变量,多个变量使用” , “ 分隔。这里假如你有数据是 int 类 型的,也要在 Parameter types 那里标示为 varchar 类型,否则无法运行。

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

2、传递的参数值是变量,使用${变量名}的方式

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

五、Variables names 参数使用方法:

jmeter 官网给的解释是:如果给这个参数设置了值,它会保存 sql 语句返回的数据和返回数据的总行数。 假如,sql 语句返回 2 行,3 列,且 variables names 设置为 A,C,那么如下变量会被设置为:

A_#=2 (总行数)
A_1=第 1 列, 第 1 行
A_2=第 1 列, 第 2 行
C_#=2 (总行数)
C_1=第 3 列, 第 1 行
C_2=第 3 列, 第 2 行

如果返回结果为 0,那么 A_#和 C_#会被设置为 0,其它变量不会设置值。 如果第一次返回 6 行数据,第二次只返回 3 行数据,那么第一次那多的 3 行数据变量会被清除。 可以使用KaTeX parse error: Expected group after '_' at position 3: {A_̲#}、{A_1}…来获取相应的值

示例:我们还是用上面的数据库,把所有数据查出来,test 表有有 3 个字段,5 条记录(忘记了的可以回到 第一步那里查看)

1、添加一个jdbc request名为”参数4“,添加一个”Debug Sampler“用来查看输出的结果,设置 variables name 为 column1,column2,column3:

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

2、执行结果:

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

解析:column1 代表第一列所有的数据,column1_#可以获取到第一列的行数 column1_n:获得第一列第 n 行的数据。 column2 和 column3 的功能类似, 假如我们只需要第一列和第三列的数据,可以写成 column1,column3,中间的","不可以省略。

六、Result variable name 参数使用方法:

如果给这个参数设置值,它会创建一个对象变量,保存所有返回的结果,获取具体值的方法:columnValue = vars.getObject(“resultObject”).get(0).get(“Column Name”)

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

执行结果:

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

到此这篇关于python软件测试Jmeter性能测试JDBC Request(结合数据库)的使用详解的文章就介绍到这了,更多相关python Jmeter性能测试 内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Python 相关文章推荐
用Python的pandas框架操作Excel文件中的数据教程
Mar 31 Python
Python文本相似性计算之编辑距离详解
Nov 28 Python
python制作爬虫爬取京东商品评论教程
Dec 16 Python
Pandas之drop_duplicates:去除重复项方法
Apr 18 Python
在pycharm中使用git版本管理以及同步github的方法
Jan 16 Python
Django实现发送邮件功能
Jul 18 Python
Python如何实现强制数据类型转换
Nov 22 Python
python使用paramiko实现ssh的功能详解
Mar 06 Python
Python应用实现双指数函数及拟合代码实例
Jun 19 Python
python 生成器需注意的小问题
Sep 29 Python
selenium与xpath之获取指定位置的元素的实现
Jan 26 Python
python 爬取哔哩哔哩up主信息和投稿视频
Jun 07 Python
Python数据模型与Python对象模型的相关总结
Jan 26 #Python
使用豆瓣源来安装python中的第三方库方法
Jan 26 #Python
详解用selenium来下载小姐姐图片并保存
Jan 26 #Python
selenium与xpath之获取指定位置的元素的实现
Jan 26 #Python
详解Python中的Lock和Rlock
Jan 26 #Python
5分钟快速掌握Python定时任务框架的实现
Jan 26 #Python
Python爬虫自动化爬取b站实时弹幕实例方法
Jan 26 #Python
You might like
php面向对象全攻略 (十一)__toString()用法 克隆对象 __call处理调用错误
2009/09/30 PHP
php 文件上传代码(限制jpg文件)
2010/01/05 PHP
深入理解php的MySQL连接类
2013/06/07 PHP
CI框架开发新浪微博登录接口源码完整版
2014/05/28 PHP
thinkPHP3.2使用RBAC实现权限管理的实现
2019/08/27 PHP
PHP中->和=>的含义及使用示例解析
2020/08/06 PHP
jQuery 瀑布流 浮动布局(一)(延迟AJAX加载图片)
2012/05/23 Javascript
jQuery添加和删除指定标签的方法
2015/12/16 Javascript
不定义JQuery插件 不要说会JQuery
2016/03/07 Javascript
如何高效率去掉js数组中的重复项
2016/04/12 Javascript
深入理解Javascript中的自执行匿名函数
2016/06/03 Javascript
jquery常用的12个小功能
2016/07/22 Javascript
JavaScript实战(原生range和自定义特效)简单实例
2016/08/21 Javascript
AngularJS中$http服务常用的应用及参数
2016/08/22 Javascript
模板视图和AngularJS之间冲突的解决方法
2016/11/22 Javascript
基于vue.js无缝滚动效果
2018/01/25 Javascript
react router4+redux实现路由权限控制的方法
2018/05/03 Javascript
Vue如何实现变量表达式选择器
2021/02/18 Vue.js
[41:11]完美世界DOTA2联赛PWL S2 Inki vs Magma 第一场 11.22
2020/11/24 DOTA
[01:50:49]DOTA2-DPC中国联赛 正赛 PSG.LGD vs Aster BO3 第三场 1月24日
2021/03/11 DOTA
浅谈Python 的枚举 Enum
2017/06/12 Python
Python内置模块ConfigParser实现配置读写功能的方法
2018/02/12 Python
关于python下cv.waitKey无响应的原因及解决方法
2019/01/10 Python
Python提取特定时间段内数据的方法实例
2019/04/01 Python
python词云库wordCloud使用方法详解(解决中文乱码)
2020/02/17 Python
HTML5地理定位与第三方工具百度地图的应用
2016/11/17 HTML / CSS
用HTML5中的Canvas结合公式绘制粒子运动的教程
2015/05/08 HTML / CSS
美国办公用品购物网站:Quill.com
2016/09/01 全球购物
Betsey Johnson官网:妖娆可爱的连衣裙及鞋子、手袋和配件
2016/12/30 全球购物
美国网上书店:Barnes & Noble
2018/08/15 全球购物
俄罗斯在线购买飞机票、火车票、巴士票网站:Tutu.ru
2020/03/16 全球购物
农田水利实习自我鉴定
2013/09/19 职场文书
保护环境倡议书范文
2014/05/13 职场文书
导师就业推荐信范文
2014/05/22 职场文书
维护民族团结演讲稿
2014/08/27 职场文书
评测 | 大屏显示带收音机的高端音箱,JBL TUNE2便携式插卡音箱实测
2021/04/24 无线电