1. 程式人生 > >很好的講述DB資料與介面資料的匹配校驗

很好的講述DB資料與介面資料的匹配校驗

前言:接口出引數據與DB資料結合校驗,使校驗力度更準確~
jmeter自帶外掛JDBC Request Sampler
這個Sampler可以向資料庫傳送一個jdbc請求(sql語句),並獲取返回的資料庫資料進行操作。它經常需要和JDBC Connection Configuration配置原件(配置資料庫連線的相關屬性,如連線名、密碼等)一起使用。
setp1:準備工作
1.本文使用的是sqlserver資料庫進行測試,資料庫的使用者名稱為sa(你自己的使用者名稱),使用者名稱密碼為*********(你自己的密碼)
2.資料庫例項名:如———TMSS_DB2,庫名:seg6654,表名:configuration,表資料如下:

3、新增需要的驅動jar包
使用不同的資料庫,我們需要引入不同的jar包。
方式1:直接將jar包複製到jmeter的lib\ext目錄下
mysql資料庫:無需引入其他資料庫驅動jar包。
:下載sqljdbc42.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包,如下面引入sqlserver資料的jar包

step2:配置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:資料庫登陸的密碼
不同資料庫具體的填寫方式,可以參考下面的表格:

填寫後大致如下:

step3:配置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返回的只是一個數據,上面的方式已經可以滿足我們的需求的,但是如果我們只要public_adresskey的資料,我們如何去取呢?
這時候我們就需要JDBC Request中使用上述說的引數了
起重使用Variable names和Result variable name均可以,但取值時key不一樣,比如我們現在就如上面,加一個Debug sampler
Variable names 對應返回結果的key為count_1,Result variable name對應返回結果的key就為result。
這樣我們值的值既然賦值給一個key了,那麼我們如何獲取result中的public_adress呢?
由於結果為一個json資料格式,因此先獲取json資料,之後通過jsonpath讀取
我們增加一個Beanshell PostProcessor,通過vars.getObject(variable).get(index).get(field)函式獲取
重要的引數說明:
Variable :為Variable names或Result variable name設定的變數名稱
index:表示在查詢結果的位置(由於我前面sql語句只限制查詢content,因此為0)
field:為查詢欄位名稱
獲取到此值後跟接口出參進行一致性校驗(因為前面已經vars.put進去了~現直接使用即可)
到此結束~
另外講下JDBC其它方法的使用
step4:JDBC Request 引數化
方法(一)、定義變數,在sql query中使用變數:
1、在User Defined Variables或者TestPlan或者CSV Data Set Config 中定義一個變數:
2、sql query 中使用${變數名}的方式引用:
方法(二)、在sql query中使用”?“作為佔位符,並傳遞引數值和引數型別,如下圖所示:
1、傳遞的引數值是常量,如圖傳遞2個變數,多個變數使用” , “ 分隔。這裡假如你有資料是int型別的,也要在Parameter types 那裡標示為varchar型別,否則無法執行。
2、傳遞的引數值是變數,使用${變數名}的方式
step5: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,中間的","不可以省略。
step6:Result variable name 引數使用方法:
如果給這個引數設定值,它會建立一個物件變數,儲存所有返回的結果,獲取具體值的方法:columnValue = vars.getObject("resultObject").get(0).get("Column Name")
執行結果: