JDBC Request
这个Sampler可以向数据库发送一个jdbc请求(sql语句),并获取返回的数据库数据进行操作。它经常需要和JDBC Connection Configuration配置原件(配置数据库连接的相关属性,如连接名、密码等)一起使用。
使用不同的数据库,我们需要引入不同的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包,如下面引入mysql数据库的jar包
此处配置说明如下:
Variable Name for created pool:此处名称自行设置;
Connection Pool Configuration:此处设置中除了Max Number of Connections需要根据线程数做修改外其他可以用默认配置;
Database Connection Configuration:此部分配置即与常用的数据库连接所需内容相同,url,驱动,用户名和密码
不同数据库具体的填写方式,可以参考下面的表格:
Database | Driver class | Database URL |
---|---|---|
MySQL | com.mysql.jdbc.Driver | jdbc:mysql://host:port/{dbname} |
PostgreSQL | org.postgresql.Driver | jdbc:postgresql:{dbname} |
Oracle | oracle.jdbc.driver.OracleDriver | jdbc:oracle:thin:user/pass@//host:port/service |
Ingres (2006) | ingres.jdbc.IngresDriver | jdbc:ingres://host:port/db[;attr=value] |
MSSQL | com.microsoft.sqlserver.jdbc.SQLServerDriver或者net.sourceforge.jtds.jdbc.Driver | jdbc:sqlserver://IP:1433;databaseName=DBname或者jdbc:jtds:sqlserver://localhost:1433/"+"library" |
重要的参数说明:
执行到这里,我们已经将数据从数据库中原样的查出来了,但具体如何之取出我们需要的数据呢,显然,假如我们查询的sql返回的只是一个数据,上面的方式已经可以满足我们的需求的,如我们查询数据的记录数
select count(*) from test
查询出来的结果就是我们需要的内容,或者通过正则表达式的获取即可获取我们的内容。
但假如像上面那样子,我们获取出来的是多行数据,我们需要如何来对数据进行遍历,只获取出我们需要的数据呢?请看下面的分析。
方法一、Jmeter参数化,在sql query中使用变量
1、Jmeter参数化,可以参考文章
2、sql query中使用${变量名}引用
方法二、在sql query中使用”?“作为占位符,并传递参数值和参数类型
1、传递的参数值是常量,多个变量使用 “,”号分隔
2、传递的参数值是变量,使用${变量名}的方式
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行
实例
添加一个”Debug Sampler“用来查看输出的结果,设置 variables name为did,typename:
执行结果
解析:
如果给这个参数设置值,它会创建一个对象变量,保存所有返回的结果,获取具体值的方法
执行结果
原文:https://www.cnblogs.com/kuaileya/p/12085268.html