【完整】Jmeter JDBC Request查询出多条SQL之间传参用法

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 测试结果
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,047评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,807评论 3 386
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,501评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,839评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,951评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,117评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,188评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,929评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,372评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,679评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,837评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,536评论 4 335
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,168评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,886评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,129评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,665评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,739评论 2 351

推荐阅读更多精彩内容