




版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
Loadrunner測(cè)試數(shù)據(jù)庫(kù)性能,測(cè)試SQL語(yǔ)句性能的腳本例子此代碼為L(zhǎng)oadrunner8通過(guò)CAPI類型的Vuser測(cè)試MySQL性能,或者測(cè)試sql語(yǔ)句性能的腳本。這東西很少有人用,網(wǎng)上資料很少,一般測(cè)試B/S的很多。viewplaincopytoclipboardprint?/*需要的表結(jié)構(gòu)如下CREATETABLE、test_data、(、order_id'BIGINTUNSIGNEDNOTNULLCOMMENT'Ordernumbers.Mustbeunique.',、status、BOOLNOTNULLDEFAULT'O'COMMENT'Whetherdatahasbeenusedornot.Avalueof0meansFALSE.','date_used、DATETIMENULLCOMMENT'Date/timethatthedatawasused.',UNIQUE('order_id'))ENGINE=innodbCOMMENT='LoadRunnertestdata';*/Action(){intrc;intdb_connection;//數(shù)據(jù)庫(kù)連接intquery_result;//查詢結(jié)果集MYSQL_RESchar**result_row;//查詢的數(shù)據(jù)衕char*server="localhost";char*user="root";char*password="123456";char*database="test";intport=33O6;intunix_socket=NULL;intflags=O;//找到libmysql.dll的所在位置.rc=lr_load_dll("C:\\ProgramFiles\\MySQL\\MySQLServer5.1\\bin\\libmysql.dll");if(rc!=O){lr_error_message("Couldnotloadlibmysql.dll");lr_abort();}//創(chuàng)建MySQL對(duì)象db_connection=mysql_init(NULL);if(db_connection==NULL){lr_error_message("Insufficientmemory");lr_abort();}//連接到MySQL數(shù)據(jù)庫(kù)rc=mysql_real_connect(db_connection,server,user,password,database,port,unix_socket,flags);if(rc==NULL){lr_error_message("%s",mysql_error(db_connection));mysql_close(db_connection);lr_abort();}//向數(shù)據(jù)庫(kù)插入數(shù)據(jù)//此處的{ORDER_ID}是一個(gè)參數(shù),簡(jiǎn)單測(cè)試時(shí)可以用一個(gè)常數(shù)代替lr_save_string(lr_eval_string("INSERTINTOtest_data(order_id)VALUES({ORDER_ID})"),"paramInsertQuery");rc=mysql_query(db_connection,lr_eval_string("{paramInsertQuery}"));if(rc!=0){lr_error_message("%s",mysql_error(db_connection));mysql_close(db_connection);lr_abort();}//從數(shù)據(jù)庫(kù)讀取一個(gè)數(shù)據(jù)并顯示rc=mysql_query(db_connection,"SELECTorder_idFROMtest_dataWHEREstatusISFALSELIMIT1");if(rc!=0){lr_error_message("%s",mysql_error(db_connection));mysql_close(db_connection);lr_abort();}query_result=mysql_use_result(db_connection);if(query_result==NULL){lr_error_message("%s",mysql_error(db_connection));mysql_free_result(query_result);mysql_close(db_connection);lr_abort();}//如果結(jié)果集包含多行數(shù)據(jù),需要多次調(diào)用mysql_fetch_row直到返回NULLresult_row=(char**)mysql_fetch_row(query_result);if(result_row==NULL){lr_error_message("Didnotexpecttheresultsettobeempty");mysql_free_result(query_result);mysql_close(db_connection);lr_abort();}//保存參數(shù),用于刪除這行數(shù)據(jù)lr_save_string(result_row[0],"paramOrderID");lr_output_message("OrderIDis:%s",lr_eval_string("{paramOrderID}"));mysql_free_result(query_result);//在事務(wù)里更新一行數(shù)據(jù),需要用InnoDB引擎rc=mysql_query(db_connection,"BEGIN");//啟動(dòng)事務(wù)if(rc!=0){lr_error_message("%s",mysql_error(db_connection));mysql_close(db_connection);lr_abort();}//使用"FORUPDATE"鎖住要更新的數(shù)據(jù)行rc=mysql_query(db_connection,"SELECTorder_idFROMtest_dataWHEREstatusISFALSELIMIT1FORUPDATE");if(rc!=0){lr_error_message("%s",mysql_error(db_connection));mysql_close(db_connection);lr_abort();}query_result=mysql_use_result(db_connection);if(query_result==NULL){lr_error_message("%s",mysql_error(db_connection));mysql_free_result(query_result);mysql_close(db_connection);lr_abort();}result_row=(char**)mysql_fetch_row(query_result);if(result_row==NULL){lr_error_message("沒(méi)有查詢到結(jié)果");mysql_free_result(query_result);mysql_close(db_connection);lr_abort();}lr_save_string(result_row[0],"paramOrderID");lr_output_message("OrderIDis:%s",lr_eval_string("{paramOrderID}"));mysql_free_result(query_result);lr_save_string(lr_eval_string("UPDATEtest_dataSETstatus=TRUE,date_used=NOW()WHEREorder_id='{paramOrderID}'"),"paramUpdateQuery");rc=mysql_query(db_connection,lr_eval_string("{paramUpdateQuery}"));if(rc!=0){lr_error_message("%s",mysql_error(db_connection));mysql_close(db_connection);lr_abort();}rc=mysql_query(db_connection,"COMMIT");//提交事務(wù)if(rc!=0){lr_error_message("%s",mysql_error(db_connection));mysql_close(db_connection);lr_abort();}//再次查找數(shù)據(jù),應(yīng)該為空了,因?yàn)榍懊娴氖聞?wù)更新了標(biāo)志rc=mysql_query(db_connection,"SELECTorder_idFROMtest_dataWHEREstatusISFALSELIMIT1");if(rc!=0){lr_error_message("%s",mysql_error(db_connection));mysql_close(db_connection);lr_abort();}query_result=mysql_use_result(db_connection);if(query_result==NULL){lr_error_message("%s",mysql_error(db_connection));mysql_free_result(query_result);mysql_close(db_connection);lr_abort();}result_row=(char**)mysql_fetch_row(query_result);if(result_row==NULL){lr_output_message("Resultsetisemptyasexpected");mysql_free_result(query_result);}else{lr_error_message("Didnotexpecttheresultsettocontainanyrows");mysql_free_result(query_result);mysql_close(db_connection);lr_abort();//刪除數(shù)據(jù)lr_save_string(lr_eval_string("DELETEFROMtest_dataWHEREorder_id='{paramOrderID}'"),"paramDeleteQuery");rc=mysql_query(db_connection,lr_eval_string("{paramDeleteQuery}"));if(rc!=0){lr_error_message("%s",mysql_error(db_connection));mysql_close(db_connection);lr_abort();}//釋放MySQL資源mysql_close(db_connection);return0;}/*需要的表結(jié)構(gòu)如下CREATETABLE、test_data、(、order_id'BIGINTUNSIGNEDNOTNULLCOMMENT'Ordernumbers.Mustbeunique.',、status、BOOLNOTNULLDEFAULT'O'COMMENT'Whetherdatahasbeenusedornot.Avalueof0meansFALSE.','date_used、DATETIMENULLCOMMENT'Date/timethatthedatawasused.',UNIQUE('order_id'))ENGINE=innodbCOMMENT='LoadRunnertestdata';*/Action(){intrc;intdb_connection;//數(shù)據(jù)庫(kù)連接intquery_result;//查詢結(jié)果集MYSQL_RESchar**result_row;//查詢的數(shù)據(jù)衕char*server="localhost";char*user="root";char*password="123456";char*database="test";intport=33O6;intunix_socket=NULL;intflags=O;//找到libmysql.dll的所在位置.rc=lr_load_dll("C:\\ProgramFiles\\MySQL\\MySQLServer5.1\\bin\\libmysql.dll");if(rc!=0){lr_error_message("Couldnotloadlibmysql.dll");lr_abort();}//創(chuàng)建MySQL對(duì)象db_connection=mysql_init(NULL);if(db_connection==NULL){lr_error_message("Insufficientmemory");lr_abort();}//連接到MySQL數(shù)據(jù)庫(kù)rc=mysql_real_connect(db_connection,server,user,password,database,port,unix_socket,flags);if(rc==NULL){lr_error_message("%s",mysql_error(db_connection));mysql_close(db_connection);lr_abort();}//向數(shù)據(jù)庫(kù)插入數(shù)據(jù)//此處的{ORDER_ID}是一個(gè)參數(shù),簡(jiǎn)單測(cè)試時(shí)可以用一個(gè)常數(shù)代替lr_save_string(lr_eval_string("INSERTINTOtest_data(order_id)VALUES({ORDER_ID})"),"paramInsertQuery");rc=mysql_query(db_connection,lr_eval_string("{paramInsertQuery}"));if(rc!=0){lr_error_message("%s",mysql_error(db_connection));mysql_close(db_connection);lr_abort();}//從數(shù)據(jù)庫(kù)讀取一個(gè)數(shù)據(jù)并顯示rc=mysql_query(db_connection,"SELECTorder_idFROMtest_dataWHEREstatusISFALSELIMIT1");if(rc!=0){lr_error_message("%s",mysql_error(db_connection));mysql_close(db_connection);lr_abort();}query_result=mysql_use_result(db_connection);if(query_result==NULL){lr_error_message("%s",mysql_error(db_connection));mysql_free_result(query_result);mysql_close(db_connection);lr_abort();}//如果結(jié)果集包含多行數(shù)據(jù),需要多次調(diào)用mysql_fetch_row直到返回NULLresult_row=(char**)mysql_fetch_row(query_result);if(result_row==NULL){lr_error_message("Didnotexpecttheresultsettobeempty");mysql_free_result(query_result);mysql_close(db_connection);lr_abort();}//保存參數(shù),用于刪除這行數(shù)據(jù)lr_save_string(result_row[0],"paramOrderID");lr_output_message("OrderIDis:%s",lr_eval_string("{paramOrderID}"));mysql_free_result(query_result);//在事務(wù)里更新一行數(shù)據(jù),需要用InnoDB引擎rc=mysql_query(db_connection,"BEGIN");//啟動(dòng)事務(wù)if(rc!=0){lr_error_message("%s",mysql_error(db_connection));mysql_close(db_connection);lr_abort();}//使用"FORUPDATE"鎖住要更新的數(shù)據(jù)行rc=mysql_query(db_connection,"SELECTorder_idFROMtest_dataWHEREstatusISFALSELIMIT1FORUPDATE");if(rc!=0){lr_error_message("%s",mysql_error(db_connection));mysql_close(db_connection);lr_abort();}query_result=mysql_use_result(db_connection);if(query_result==NULL){lr_error_message("%s",mysql_error(db_connection));mysql_free_result(query_result);mysql_close(db_connection);lr_abort();}result_row=(char**)mysql_fetch_row(query_result);if(result_row==NULL){lr_error_message("沒(méi)有查詢到結(jié)果");mysql_free_result(query_result);mysql_close(db_connection);lr_abort();}lr_save_string(result_row[0],"paramOrderID");lr_output_message("OrderIDis:%s",lr_eval_string("{paramOrderID}"));mysql_free_result(query_result);lr_save_string(lr_eval_string("UPDATEtest_dataSETstatus=TRUE,date_used=NOW()WHEREorder_id='{paramOrderID}'"),"paramUpdateQuery");rc=mysql_query(db_connection,lr_eval_string("{paramUpdateQuery}"));if(rc!=0){lr_error_message("%s",mysql_error(db_connection));mysql_close(db_connection);lr_abort();}rc=mysql_query(db_connection,"COMMIT");//提交事務(wù)if(rc!=0){lr_error_message("%s",mysql_error(db_connection));mysql_close(db_connection);lr_abort();}//再次查找數(shù)據(jù),應(yīng)該為空了,因?yàn)榍懊娴氖聞?wù)更新了標(biāo)志rc=mysql_query(db_connection,"SELECTorder_idFROMtest_dataWHER
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 2025年 長(zhǎng)沙市北雅中學(xué)招聘教師考試試題附答案
- 中國(guó)活動(dòng)扳手行業(yè)市場(chǎng)運(yùn)營(yíng)態(tài)勢(shì)分析及投資前景預(yù)測(cè)報(bào)告
- 2025年中國(guó)關(guān)節(jié)內(nèi)窺鏡行業(yè)市場(chǎng)深度分析及投資策略咨詢報(bào)告
- 中國(guó)低溫粉碎機(jī)行業(yè)發(fā)展監(jiān)測(cè)及投資戰(zhàn)略規(guī)劃研究報(bào)告
- 2023-2028年中國(guó)無(wú)機(jī)陶瓷行業(yè)發(fā)展監(jiān)測(cè)及市場(chǎng)發(fā)展?jié)摿︻A(yù)測(cè)報(bào)告
- 2025年中國(guó)無(wú)功功率補(bǔ)償設(shè)備行業(yè)投資分析及發(fā)展戰(zhàn)略咨詢報(bào)告
- 中國(guó)游泳池自動(dòng)水處理系統(tǒng)項(xiàng)目投資可行性研究報(bào)告
- 中國(guó)太陽(yáng)能單晶硅棒行業(yè)發(fā)展監(jiān)測(cè)及投資戰(zhàn)略規(guī)劃報(bào)告
- 2020-2025年中國(guó)現(xiàn)代農(nóng)業(yè)產(chǎn)業(yè)園區(qū)行業(yè)投資研究分析及發(fā)展前景預(yù)測(cè)報(bào)告
- 中國(guó)半導(dǎo)體照明光源行業(yè)市場(chǎng)全景監(jiān)測(cè)及投資策略研究報(bào)告
- GB/T 42001-2022高壓輸變電工程外絕緣放電電壓海拔校正方法
- GB/T 41837-2022溫泉服務(wù)溫泉水質(zhì)要求
- YY/T 1467-2016醫(yī)用包扎敷料救護(hù)繃帶
- GB/T 6495.3-1996光伏器件第3部分:地面用光伏器件的測(cè)量原理及標(biāo)準(zhǔn)光譜輻照度數(shù)據(jù)
- GB/T 17193-1997電氣安裝用超重荷型剛性鋼導(dǎo)管
- 2023年九年級(jí)中考數(shù)學(xué)高頻考點(diǎn)突破-圓的切線的證明【含答案】
- 2023年內(nèi)江市市中區(qū)財(cái)政局系統(tǒng)事業(yè)單位招聘筆試題庫(kù)及答案解析
- 國(guó)際貿(mào)易實(shí)務(wù)全部資料課件
- 帶狀皰疹醫(yī)學(xué)課件
- 全國(guó)卷高考標(biāo)準(zhǔn)語(yǔ)文答題卡作文紙3欄800字版
- 事業(yè)單位招聘考試《工程建設(shè)管理專業(yè)知識(shí)》真題匯總及答案【含解析】
評(píng)論
0/150
提交評(píng)論