JDBC Connection使用


准備工作: 數據庫jar的引用

一、JDBC Connection 配置信息

 

重要參數說明

  • Variable Name:數據庫連接池的名稱,我們可以有多個jdbc connection configuration,每個可以起個不同的名稱,在jdbc request中可以通過這個名稱選擇合適的連接池進行使用。
  • Database URL:數據庫url,jdbc:mysql://主機ip或者機器名稱:mysql監聽的端口號/數據庫名稱, 如:jdbc:mysql://localhost:3306/test
  • JDBC Driver class:JDBC驅動
  • username:數據庫登陸的用戶名
  • passwrod:數據庫登陸的密碼

 

二、JDBC Request 使用

 

 

 

 

  • Variable Name:數據庫連接池的名字,需要與JDBC Connection Configuration的Variable Name Bound Pool名字保持一致
  • Query:填寫的sql語句
  • Parameter valus:參數值
  • Parameter types:參數類型,可參考:Javadoc for java.sql.Types
  • Variable names:保存sql語句返回結果的變量名【value形式保存結果】
  • Result variable name:創建一個對象變量,保存所有返回的結果【key  value形式保存的結果】
  • Query timeout:查詢超時時間
  • Handle result set:定義如何處理由callable statements語句返回的結果

 

執行到這里,我們已經將數據從數據庫中原樣的查出來了,但具體如何之取出我們需要的數據呢,顯然,假如我們查詢的sql返回的只是一個數據,上面的方式已經可以滿足我們的需求的,如我們查詢數據的記錄數
 
select count(*) from test
 

 

 

 

 

 


查詢出來的結果就是我們需要的內容,或者通過正則表達式的獲取即可獲取我們的內容。
 
但假如像上面那樣子,我們獲取出來的是多行數據,我們需要如何來對數據進行遍歷,只獲取出我們需要的數據呢?請看下面的分析。

四、JDBC Request參數化

方法一、Jmeter參數化,在sql query中使用變量

  1. Jmeter參數化,可以參考我之前的文章
  2. sql query中使用${變量名}引用

方法二、在sql query中使用”?“作為占位符,並傳遞參數值和參數類型
 

  1. 傳遞的參數值是常量,多個變量使用","分隔

     
  2. 傳遞的參數值是變量,使用${變量名}的方式

 

五、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行
 

  • 如果返回結果為0,那么A_#和C_#會被設置為0,其它變量不會設置值。
  • 如果第一次返回6行數據,第二次只返回3行數據,那么第一次那多的3行數據變量會被清除。
  • 可以使用${A_#}、${A_1}...獲取相應的值
     

實例
添加一個”Debug Sampler“用來查看輸出的結果,設置 variables name為column1,column2,column3:

 
執行結果

 
解析:

  • column1代表第一列所有的數據,column1_#可以獲取到第一列的行數
     
  • column1_n:獲得第一列第n行的數據。
     
  • column2和column3的功能類似, 假如我們只需要第一列和第三列的數據,可以寫成column1,,column3,中間的","不可以省略。
     

六、Result variable name 參數使用方法

如果給這個參數設置值,它會創建一個對象變量,保存所有返回的結果,獲取具體值的方法:columnValue = vars.getObject("resultObject").get(0).get("Column Name")
 

 
執行結果

 

 

 

 

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM