美文网首页Apache JMeterJmeter性能测试工具jmeter接口测试
【完整】Jmeter JDBC Request查询出多条SQL之

【完整】Jmeter JDBC Request查询出多条SQL之

作者: 乘风破浪的姐姐 | 来源:发表于2017-09-29 11:25 被阅读195次

    Jmeter 建立oracle链接后,需要查询多条sql语句,且第一条sql语句的查询结果,要作为后续sql语句的参数。

    前提条件:

    1、oracle 可成功连接

    2、存在表1 t_accident、表二 t_acc_policy,且 表1的accident_id 是表2的外键

    具体操作如下:

    1、下载ojdbc14.jar,并将其放至Jmeter路径下(..\apache-jmeter-2.7\lib);否则会报错  Cannot load JDBC driver class 'oracle.jdbc.driver.OracleDriver'

    2、选中测试计划,新增 线程组

    3、选中线程组-->配置元件,添加一个jdbc connection configuration。

    Variable Name Bound to Pool:该值在整个测试计划中应该是唯一的,后面会使用到

    DatabaseURL:jdbc:oracle:thin:@数据库IP:1521:数据库ID      数据库连接串

    JDBC Driver class:oracle.jdbc.driver.OracleDriver  数据库驱动程序

    Username:数据库用户名

    Password:对应的数据库用户密码

    jdbc connection configuration

    4、选中线程组-->sampler,添加 2个 jdbc request,第一个用于查询accident_id,第二个用于查询表二t_acc_policy

    注意:

    1)、Variable Name:需要配置Variable Name Bound to Pool的Variable Name  与JDBC Connection Configuration中的一致

    2)、Query Type:SQL的类型。

    Select Statement, Query内容为一条查询语句时选择此项 ;

    Callable statement,多个查询语句(不使用参数的情况下)可以放在一起顺序执行;

    Prepared Select Statement,查询SQL需传递参数选择此项;

    Update statement,这是一个更新语句类型(包含insert和update)。如果JDBC Request中的Query内容为一条更新语句,则选择这种类型。如果该类型下写入多条update语句,只执行第一条

    Prepared update statement,当进行增、删、改SQL语句需传递参数选择此项;

    3)、输入对应SQL,如果只有单条SQL,则不要添加分号(;),如果有多条,需要在不是最后一条的其他sql结尾处加分号。

    4)、variables name:可以设置为column1,column2,column3....

    column1代表第一列所有的数据,column1_#可以获取到第一列的行数

    column1_n:获得第一列第n行的数据。

    column2和column3的功能类似, 假如我们只需要第一列和第三列的数据,可以写成column1,,column3,中间的","不可以省略。

    因为"columnN"可以是任意字符,这里查询的最终结果只有一列,所以设置为accident_id。

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

    第一个jdbc request 第二个jdbc request( 1)

    第二个jdbc request 也可以使用“?”作为占位符,并传递参数值和参数类型。多个变量使用” , “ 分隔。这里假如你有数据是int类型的,也要在Parameter types 那里标示为varchar类型,否则无法运行。

    第二个jdbc request (2)

    5、可以看到,在第二个 jdbc request 中,select语句中出现了变量${accident_id},那我们可以添加一个【用户定义的变量】,名称就是我们的sql语句里面的变量引用名accident_id。点击测试计划,新增用户定义的变量;或者,选中线程组-->配置元件,新增用户定义的变量

    用户定义的变量

    6、第二个jdbc request 中设置了Result variable name=“selectResult”,为了看到这个对象显示效果,可以选中该jdbc request-->后置处理器,新增BeanShell PostProcessor,获取查询结果中,某列的值。

    BeanShell PostProcessor

    7、选中 线程组--->sampler,新增 Debug Sampler方便查看BeanShell PostProcessor返回结果,不用修改任何配置。

    1)、Debug Sampler响应数据中accident_id_1为第一个 jdbc request 输出的参数值,即第二个 jdbc request需要的参数值,所以在用户定义的变量中,引用为${accident_id_1}。

    2)、Debug Sampler响应数据中 address 即为BeanShell PostProcessor中要 get的值。

    Debug Sampler

    8、选中线程组,添加--->监听器--->查看结果树/图形结果,便于查看测试结果

    第一个 jdbc request 测试结果 第二个 jdbc request 测试结果

    相关文章

      网友评论

        本文标题:【完整】Jmeter JDBC Request查询出多条SQL之

        本文链接:https://www.haomeiwen.com/subject/uiabextx.html