Jmeter執行多個sql查詢語句


1.添加jdbc connection(注意標紅部分)

2.添加jdbc request

3.查看結果樹

 

本文主要向大家介紹了Oracle數據庫之jmeter jdbc request 如何運行多個sql,通過具體的內容向大家展現,希望對大家學習Oracle數據庫有所幫助。

database url:jdbc:mysql://127.0.0.1:3306/api?useUnicode=true&allowMultiQueries=true&characterEncoding=utf8

注意:太低版本的mysql和jdbc不支持,最好用最新版的
 
JDBC Request

  這個Sampler可以向數據庫發送一個jdbc請求(sql語句),並獲取返回的數據庫數據進行操作。它經常需要和JDBC Connection Configuration配置原件(配置數據庫連接的相關屬性,如連接名、密碼等)一起使用。

一、准備工作
1、本文使用的是mysql數據庫進行測試,數據庫的用戶名為root(你自己的用戶名),用戶名密碼為*********(你自己的密碼)

2、數據庫中有表:test,表的數據結構如下:

表中數據如下:

select * from test

3、添加需要的驅動jar包

  使用不同的數據庫,我們需要引入不同的jar包。

 

方式1:直接將jar包復制到jmeter的lib目錄

mysql數據庫:無需引入其他數據庫驅動jar包。

sql server 數據庫:下載sqljdbc4.jar 放到 jmeter根目錄的lib目錄下

oracle數據庫:將oracle數據的安裝目錄下面的\product\10.2.0\db_1\jdbc\lib\ojdbc14.jar 放到jmeter根目錄下的lib目錄下

方式2:通過Test Plan

  假如我們不使用將jar復制到jmeter的lib目錄的方式,我們還可以使用Jmeter的Test Plan引入相應的jar包,如下面引入oracle數據的jar包

二、配置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
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"
 
三、配置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}‘

方法(二)、在sql query中使用”?“作為占位符,並傳遞參數值和參數類型,如下圖所示:

1、傳遞的參數值是常量,如圖傳遞2個變量,多個變量使用” , “ 分隔。這里假如你有數據是int類型的,也要在Parameter types 那里標示為varchar類型,否則無法運行。

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}...來獲取相應的值。

示例:
  我們還是用上面的數據庫,把所有數據查出來,test表有有3個字段,5條記錄(忘記了的可以回到第一步那里查看)
1、添加一個jdbc request名為”參數4“,添加一個”Debug Sampler“用來查看輸出的結果,設置 variables name為column1,column2,column3:

2、執行結果:
  解析:
  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