JMeter数据库操作详解

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JMeter数据库操作详解相关的知识,希望对你有一定的参考价值。

Jmeter提供了JDBC连接的插件,通过执行SQL语句的java API,实现对数据库的访问和查询。

一、安装驱动包

  将需要连接JDBC的jar包放入jmeter安装文件的lib文件中(也可测试计划中的导入)

二、配置JDBC Connection configuration

  右键线程组→添加→配置元件→JDBC Connection configuration

    技术分享

  技术分享

Variable Name:数据库连接池的名称,在使用JDBC Request时通过该连接池名称进行连接,因此在使用JDBC Request时输入的连接池名称要与JDBC Connection Configuration中的一致。

Connection Pool Configuration中定义了基本配置,可以设置其为默认值。主要需要关注的是Database Configuration中的配置:

  Database URL:为数据库的URL,jdbc:mysql://服务器地址:监听端口/数据库名称

  JDBC Driver class:JDBC驱动。一般为com.mysql.jdbc.Driver 或 ort.gjt.mm.mysql.Driver

  Username:数据库的用户名

  Password:数据库密码

三、设置JDBC Request
    技术分享

  Variable Name:数据库连接池的名称;

  Query Type:查询类型。例如,使用select查询时使用Select Statement,使用delete删除表时使用Update Statement;

  Query:在此可以使用数据库操作语句

  Parameter Name:引用的参数值

  Parameter Type:引用参数值的类型

  Variable name:使用sql语句返回的变量名

  Result Variable name:定义一个参数的名称用于保存sql查询结果的返回值

  Query time:设置定时器时间

  Handle Result:参数保存时的保存类型

    技术分享

四、参数化的使用方法

  方式一:使用${变量名},例如:select   *  from  table1  where  pwd=${password}; 

  变量password可以通过用户自定义变量中设置,或者通过其他响应报文中提取出来的值

  方式二:使用Parameter Name

  使用占位符?来代替参数值,在Parameter Name中填入参数值,严格限制参数值的顺序。而Parameter Type中填入的是相对应的参数值类型

      技术分享

  方式三:使用Variable names

  在Variable names中设置的变量名对应代表了数据库中相应的列,利用逗号隔开,如A1代表第一列的所有内容,A3代表第三列的所有内容。若要取第一列第二行的内容,则可以用A1_2表示;

  若要取得A1列的总行数,则用A1_#表示,在外部引用该变量时可以直接利用${A1_2}获取,此时取的是第一列第二行的内容。

  技术分享

  下面利用BeanShell来打印A3_1和A1_#的值,即取第三行第一列的值和取第一列的行数

   技术分享

  通过查看控制台得:技术分享

 

 附:数据库连接driverClass和jdbcUrl大全

一、Mysql:

  driverClass:com.mysql.jdbc.Driver

      org.gjt.mm.mysql.Driver

  jdbcUrl:jdbc:mysql://192.168.0.1:3306/yourDBName

二、oracle

  (thin模式)

  driverClass:oracle.jdbc.driver.OracleDriver

  jdbcUrl:jdbc:oracle:thin:@192.168.0.1:1521:yourDBName

三、SQL Server:

  driverClass:com.microsoft.sqlserver.jdbc.SQLServerDriver(2005版本及以后)

                    com.microsoft.jdbc.sqlserver.SQLServerDriver(2000版本)

  jdbcUrl:jdbc:sqlserver://192.168.0.1:1433;databasename=yourDBName

四、Sybase:

  driverClass:com.sybase.jdbc3.jdbc.SybDriver
                         com.sysbase.jdbc.SybDriver

  jdbcUrl:jdbc:sybase:Tds:127.0.0.1:5007/myDB

五、DB2:

1、db2java.zip

  driverClass:COM.ibm.db2.jdbc.NET.DB2Driver

  jdbcUrl:jdbc:db2://127.0.0.1:5000/DBNAME

2、db2jcc.jar

  driverClass:com.ibm.db2.jcc.DB2DriverjdbcUrl:jdbc:db2://127.0.0.1:5000/DBNAME

3、driverClass:com.ibm.db2.jdbc.app.DB2DriverjdbcUrl:jdbc:db2://127.0.0.1:5000/yourDBName

 


以上是关于JMeter数据库操作详解的主要内容,如果未能解决你的问题,请参考以下文章

jmeter使用详解

Jmeter(十七) - 从入门到精通 - JMeter后置处理器 -上篇(详解教程)

Jmeter(十八) - 从入门到精通 - JMeter后置处理器 -下篇(详解教程)

jmeter5.2版本 配置元件之逻辑控制器详解

jmeter的基本功能使用详解

jmeter操作数据库