JDBC Request
這個Sampler可以向數據庫發送一個jdbc請求(sql語句),并獲取返回的數據庫數據進行操作。它經常需要和JDBC Connection Configuration配置原件(配置數據庫連接的相關屬性,如連接名、密碼等)一起使用。
一、準備工作
1、本文使用的是mysql數據庫進行測試
2、數據庫中有表:user,表的數據結構如下:
3、下載mysql-connector-java-5.1.41,將jar包放置到Jmeter安裝目錄下的lib目錄下
二、配置JDBC Connection Configuration
添加JDBC Connection Configuration組件
參數說明:
- 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:數據庫登陸的密碼
不同數據庫具體的填寫方式,可以參考下面的表格:
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 |
三、配置JDBC Request
添加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語句返回結果的變量名
- Result variable name:創建一個對象變量,保存所有返回的結果
- Query timeout:查詢超時時間
- Handle result set:定義如何處理由callable statements語句返回的結果
配置好后,查看執行結果:
執行到這里,我們已經將數據從數據庫中原樣的查出來了,但具體如何之取出我們需要的數據呢,顯然,假如我們查詢的sql返回的只是一個數據,上面的方式已經可以滿足我們的需求的,如我們查詢數據的記錄數:
select count(*) from test
查詢出來的結果就是我們需要的內容,或者通過正則表達式的獲取即可獲取我們的內容。
但假如像上面那樣子,我們獲取出來的是多行數據,我們需要如何來對數據進行遍篩選,只獲取出我們需要的數據呢?請看下面的分析。
四、JDBC Request參數化
方法(一)、定義變量,在sql query中使用變量:
1、在Test Plan 中定義一個變量(當然也可以使用參數化:Jmeter參數化):
2、在sql query 中使用${變量名}的方式引用:
select * from test where name='${name}'
3、執行結果
方法(二)、在sql query中使用”?“作為占位符,并傳遞參數值和參數類型,如下圖所示:
1、傳遞的參數值是常量,如圖傳遞2個變量,多個變量使用“,” 分隔。這里假如你有數據是int類型的,也要在Parameter types 那里標示為varchar類型,否則無法運行。
2、傳遞的參數值是變量,使用${變量名}的方式