Jmeter之JDBCRequest及参数化
⽬录
JDBC Request
这个Sampler可以向数据库发送⼀个jdbc请求(sql语句),并获取返回的数据库数据进⾏操作。它经常需要和JDBC Connection Configuration配置原件(配置数据库连接的相关属性,如连接名、密码等)⼀起使⽤。
⼀、准备⼯作
1. 本⽂使⽤的是mysql数据库
2. 数据库中有表
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包,如下⾯引⼊mysql数据库的jar包
⼆、配置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:数据库登陆的密码
不同数据库具体的填写⽅式,可以参考下⾯的表格:
Database Driver class Database URL
sql.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"
三、配置JDBC Request
jdbc连接oracle重要的参数说明:
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语句返回的结果
执⾏到这⾥,我们已经将数据从数据库中原样的查出来了,但具体如何之取出我们需要的数据呢,显然,假如我们查询的sql返回的只是⼀个数据,上⾯的⽅式已经可以满⾜我们的需求的,如我们查询数据的记录数
select count(*) from test
查询出来的结果就是我们需要的内容,或者通过正则表达式的获取即可获取我们的内容。
但假如像上⾯那样⼦,我们获取出来的是多⾏数据,我们需要如何来对数据进⾏遍历,只获取出我们需要的数据呢?请看下⾯的分析。四、JDBC Request参数化
⽅法⼀、Jmeter参数化,在sql query中使⽤变量
1. Jmeter参数化,可以参考我之前的
2. sql query中使⽤${变量名}引⽤
⽅法⼆、在sql query中使⽤”?“作为占位符,并传递参数值和参数类型1. 传递的参数值是常量,多个变量使⽤","分隔
2. 传递的参数值是变量,使⽤${变量名}的⽅式
五、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⾏数据变量会被清除。
可以使⽤${A_#}、${A_1}...获取相应的值
实例
添加⼀个”Debug Sampler“⽤来查看输出的结果,设置 variables name为column1,column2,column3:
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论