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:对应的数据库用户密码
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 也可以使用“?”作为占位符,并传递参数值和参数类型。多个变量使用” , “ 分隔。这里假如你有数据是int类型的,也要在Parameter types 那里标示为varchar类型,否则无法运行。
5、可以看到,在第二个 jdbc request 中,select语句中出现了变量${accident_id},那我们可以添加一个【用户定义的变量】,名称就是我们的sql语句里面的变量引用名accident_id。点击测试计划,新增用户定义的变量;或者,选中线程组-->配置元件,新增用户定义的变量
6、第二个jdbc request 中设置了Result variable name=“selectResult”,为了看到这个对象显示效果,可以选中该jdbc request-->后置处理器,新增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的值。
8、选中线程组,添加--->监听器--->查看结果树/图形结果,便于查看测试结果