JDBC Requesthtml
這個Sampler能夠向數據庫發送一個jdbc請求(sql語句),並獲取返回的數據庫數據進行操做。它常常須要和JDBC Connection Configuration配置原件(配置數據庫鏈接的相關屬性,如鏈接名、密碼等)一塊兒使用。java
1、準備工做mysql
一、本文使用的是mysql數據庫進行測試,數據庫的用戶名爲root(你本身的用戶名),用戶名密碼爲*********(你本身的密碼)正則表達式
二、數據庫中有表:test,表的數據結構以下:sql
表中數據以下:數據庫
select * from test
三、添加須要的驅動jar包數據結構
使用不一樣的數據庫,咱們須要引入不一樣的jar包。oracle
方式1:直接將jar包複製到jmeter的lib目錄sqlserver
方式2:經過Test Planpost
假如咱們不使用將jar複製到jmeter的lib目錄的方式,咱們還可使用Jmeter的Test Plan引入相應的jar包,以下面引入oracle數據的jar包
2、配置JDBC Connection Configuration
重要參數說明:
不一樣數據庫具體的填寫方式,能夠參考下面的表格:
Datebase |
Driver class |
Database URL |
MySQL |
com.mysql.jdbc.Driver |
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 或者 net.sourceforge.jtds.jdbc.Driver |
jdbc:sqlserver://IP:1433;databaseName=DBname 或者 jdbc:jtds:sqlserver://localhost:1433/"+"library"
|
填寫後大體以下:
3、配置JDBC Request
重要的參數說明:
執行結果:
執行到這裏,咱們已經將數據從數據庫中原樣的查出來了,但具體如何之取出咱們須要的數據呢,顯然,假如咱們查詢的sql返回的只是一個數據,上面的方式已經能夠知足咱們的需求的,如咱們查詢數據的記錄數,
select count(*) from test
查詢出來的結果就是咱們須要的內容,或者經過正則表達式的獲取便可獲取咱們的內容。
但假如像上面那樣子,咱們獲取出來的是多行數據,咱們須要如何來對數據進行遍歷,只獲取出咱們須要的數據呢?請看下面的分析。
4、JDBC Request 參數化
方法(一)、定義變量,在sql query中使用變量:
一、在Test Plan 中定義一個變量(固然也可使用參數化:Jmeter參數化):
二、sql query 中使用${變量名}的方式引用:
select * from test where name='${name}'
方法(二)、在sql query中使用」?「做爲佔位符,並傳遞參數值和參數類型,以下圖所示:
一、傳遞的參數值是常量,如圖傳遞2個變量,多個變量使用」 , 「 分隔。這裏假如你有數據是int類型的,也要在Parameter types 那裏標示爲varchar類型,不然沒法運行。
二、傳遞的參數值是變量,使用${變量名}的方式
5、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行
示例:
咱們仍是用上面的數據庫,把全部數據查出來,test表有有3個字段,5條記錄(忘記了的能夠回到第一步那裏查看)
一、添加一個jdbc request名爲」參數4「,添加一個」Debug Sampler「用來查看輸出的結果,設置 variables name爲column1,column2,column3:
二、執行結果:
解析:
column1表明第一列全部的數據,column1_#能夠獲取到第一列的行數
column1_n:得到第一列第n行的數據。
column2和column3的功能相似, 假如咱們只須要第一列和第三列的數據,能夠寫成column1,,column3,中間的","不能夠省略。
6、Result variable name 參數使用方法:
若是給這個參數設置值,它會建立一個對象變量,保存全部返回的結果,獲取具體值的方法:columnValue = vars.getObject("resultObject").get(0).get("Column Name")
執行結果:
jmeter 簡單使用:http://www.cnblogs.com/0201zcr/p/5046193.html
jmeter 獲取返回數據做爲下一個請求參數:http://www.cnblogs.com/0201zcr/p/5089620.html
源文件:http://pan.baidu.com/s/1mh3Ag5M
致謝:感謝您的閱讀!