Jmeter执⾏多个sql查询语句
1.添加jdbc connection(注意标红部分)
2.添加jdbc request
3.查看结果树
本⽂主要向⼤家介绍了Oracle数据库之jmeter jdbc request 如何运⾏多个sql,通过具体的内容向⼤家展现,希望对⼤家学习Oracle数据库有所帮助。
database url:jdbc:mysql://127.0.0.1:3306/api?useUnicode=true&allowMultiQueries=true&characterEncoding=utf8
注意:太低版本的mysql和jdbc不⽀持,最好⽤最新版的
JDBC Request
  这个Sampler可以向数据库发送⼀个jdbc请求(sql语句),并获取返回的数据库数据进⾏操作。它经常需要和JDBC Connection Configuration配置原件(配置数据库连接的相关属性,如连接名、密码等)⼀起使⽤。
⼀、准备⼯作
1、本⽂使⽤的是mysql数据库进⾏测试,数据库的⽤户名为root(你⾃⼰的⽤户名),⽤户名密码为*********(你⾃⼰的密码)
2、数据库中有表:test,表的数据结构如下:
表中数据如下:
select * from test
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包
⼆、配置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:数据库登陆的密码
不同数据库具体的填写⽅式,可以参考下⾯的表格:
Datebase
Driver class
Database URL
MySQL
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
mysql下载jar包
或者
net.sourceforge.jtds.jdbc.Driver
jdbc:sqlserver://IP:1433;databaseName=DBname
或者
jdbc:jtds:sqlserver://localhost:1433/"+"library"
三、配置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语句返回的结果
执⾏结果:
  执⾏到这⾥,我们已经将数据从数据库中原样的查出来了,但具体如何之取出我们需要的数据呢,显然,假如我们查询的sql返回的只是⼀个数据,上⾯的⽅式已经可以满⾜我们的需求的,如我们查询数
据的记录数,
select count(*) from test
  查询出来的结果就是我们需要的内容,或者通过正则表达式的获取即可获取我们的内容。
  但假如像上⾯那样⼦,我们获取出来的是多⾏数据,我们需要如何来对数据进⾏遍历,只获取出我们需要的数据呢?请看下⾯的分析。
四、JDBC Request 参数化
⽅法(⼀)、定义变量,在sql query中使⽤变量:
1、在Test Plan 中定义⼀个变量(当然也可以使⽤参数化:Jmeter参数化):
2、sql query 中使⽤${变量名}的⽅式引⽤:
select * from test where name=‘${name}‘
⽅法(⼆)、在sql query中使⽤”?“作为占位符,并传递参数值和参数类型,如下图所⽰:
1、传递的参数值是常量,如图传递2个变量,多个变量使⽤” , “ 分隔。这⾥假如你有数据是int类型的,也要在Parameter types 那⾥标⽰为varchar类型,否则⽆法运⾏。
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}...来获取相应的值。
⽰例:
  我们还是⽤上⾯的数据库,把所有数据查出来,test表有有3个字段,5条记录(忘记了的可以回到第⼀步那⾥查看)
1、添加⼀个jdbc request名为”参数4“,添加⼀个”Debug Sampler“⽤来查看输出的结果,设置 variables name为column1,column2,column3:
2、执⾏结果:
  解析:
  column1代表第⼀列所有的数据,column1_#可以获取到第⼀列的⾏数
  column1_n:获得第⼀列第n⾏的数据。
  column2和column3的功能类似,假如我们只需要第⼀列和第三列的数据,可以写成column1,,column3,中间的","不可以省略。
六、Result variable name 参数使⽤⽅法:
  如果给这个参数设置值,它会创建⼀个对象变量,保存所有返回的结果,获取具体值的⽅法:
  columnValue = Object("resultObject").get(0).get("Column Name")

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。