loadrunner-mysql

loadrunner连接mysql

需要使用到的包:

链接:https://pan.baidu.com/s/1X5k0mZt1YpUdklyB8GqN9w&shfl=sharepset

提取码:s06a

步骤:

1、将如下代码放入vuser_init文件

#include"Ptt_Mysql.h"

#include"mysql.h"

#include"mysql_com.h"

#include"mysql_time.h"

#include"mysql_version.h"

#include"typelib.h"

#include"my_list.h"

#include"my_alloc.h"

#defineMYSQLSERVER"127.0.0.1"

#defineMYSQLUSERNAME"name"

#defineMYSQLPASSWORD"password"

#defineMYSQLDB"mysql"

#defineMYSQLPORT"3306"

charchQuery[1024];

intstatu=1;

intstatus=0;

MYSQL*Mconn;

charsql_query[256],sql_sub_query[50];

inti=0,res=0,conn_fail=0,conn_iter=0;

charresponse[50];// to go   

vuser_init()

{

lr_load_dll("libmysql.dll");

lr_start_transaction("mysql_conn");//设置一个连接数据库的事务  

/*------------------------------------------------------------------------*/

/* Initialise MySQL */

if(!(Mconn=mysql_init(NULL)))

{

lr_message("Error -1: Cannot initialize MySQL - %s",mysql_error(Mconn));

//return -1;  

statu=0;

lr_end_transaction("mysql_conn",LR_FAIL);//初始化数据库失败判定事务失败  

}

/*------------------------------------------------------------------------*/

do

{

/* Connect to database */

if(!mysql_real_connect(Mconn,MYSQLSERVER,MYSQLUSERNAME,MYSQLPASSWORD,MYSQLDB,atoi(MYSQLPORT),NULL,0))

{

conn_fail=-2;

conn_iter++;

sleep(100);

}

else

conn_fail=0;

}

while(conn_fail<0&&conn_iter<10);

if(conn_fail<0)

{

lr_message("Error -2: %s",mysql_error(Mconn));

//mysql_close(Mconn);  

//return -2;  

statu=0;

lr_end_transaction("mysql_conn",LR_FAIL);//连接数据库失败判定事务失败  

}

else

{

//lr_message("MySql - Good Connection");  

//mysql_close(Mconn);  

statu=1;

lr_end_transaction("mysql_conn",LR_PASS);//连接数据库成功,事务通过。  

}

return0;

}



2、将如下代码放入vuser_init文件

Action()

{

intcount=0;

if(statu){//成功连接数据库后才进行执行sql的操作  

lr_start_transaction("mysql_select");

sprintf(chQuery,"SELECT lower(hex(id)),title from hnt_tk_ticket ");//查询论坛用户  

//sprintf(chQuery,"UPDATE lr_test SET password = "%s" WHERE username='tom'",lr_eval_string ("{pwd}"));  

/* 

        sprintf(chQuery,"update pre_ucenter_members set username='dd' where username='qq' ");//更改用户名qq为dd 

        sprintf(chQuery,"delete from pre_ucenter_members ORDER BY uid desc LIMIT 1");//删除最后添加的一条数据 

        */

status=lr_mysql_query(Mconn,chQuery);

count=mysql_affected_rows(Mconn);

lr_output_message("xxxxxxxxxxxxx:%s",lr_eval_string("count"));

for(i=0;i<count;i++){//输出查询的值

lr_save_string(row[0][i].cell,"test");

lr_save_string(row[1][i].cell,"test2");

lr_output_message("xxxxxxxxxxxxx:%s",lr_eval_string("{test}"));

lr_output_message("xxxxxxxxxxxxx:%s",lr_eval_string("{test2}"));

}

if(status!=0){//判断sql是否执行成功  

lr_end_transaction("mysql_select",LR_FAIL);

}else{

lr_end_transaction("mysql_select",LR_PASS);

}

//        lr_start_transaction("mysql_insert");  

//        sprintf(chQuery,"insert into oa_news(id, lb, title, nr, attachment_id, attachment_name, pic_name, fbsj, fbbm, fbr, vcount) values(9,9,'qq@qq.com','test','','','teste','',6,'test',0)");//插入数据  

//        status = lr_mysql_query(Mconn, chQuery);  

//        if(status!=0){ //判断sql是否执行成功  

//            lr_end_transaction("mysql_insert",LR_FAIL);  

//        }else{  

//            lr_end_transaction("mysql_insert",LR_PASS);  

//        }  

}

return0;

}



3、将如下代码防止vuser_end文件

vuser_end()

{

lr_mysql_disconnect(Mconn);//关闭数据库连接  

return0;

}



不过这里会存在中文编码问题,如果你插入的数据有中文,需要加上mysql_query(db_connection,lr_eval_string("SET NAMES gbk"));

我连接数据库主要是想把数据写入文件中所以还在action中添加了如下代码。

char*filename="C:\\loadrunner\\mysql.dat";

longfile;

count=mysql_affected_rows(Mconn);

if((file=fopen(filename,"w+"))==NULL){

lr_output_message("Unable to create %s",filename);

return-1;

}

//获取数据,然后写入到文件中

for(i=0;i<count;i++)

{

lr_save_string(row[0][i].cell,"id");

lr_save_string(row[1][i].cell,"caseid");

lr_save_string(row[2][i].cell,"title");

//                lr_output_message("xxxxxxxxxxxxx:%s",lr_eval_string("{id}"));

//                lr_output_message(":%s",lr_eval_string("{caseid}"));

//              lr_output_message(":%s",lr_eval_string("{title}"));

strcat(row[0][i].cell," ");//用空格分隔

strcat(row[0][i].cell,row[1][i].cell);//连接      

strcat(row[0][i].cell," ");//用空格分隔

strcat(row[0][i].cell,row[2][i].cell);//连接  

strcat(row[0][i].cell,"\n");//添加回车换行标识

fwrite(row[0][i].cell,strlen(row[0][i].cell),1,file);//把一组信息写入参数文件

}

fclose(file);//关闭文件



感谢网络上各位大神的分享,从各位大神哪里学习loadrunner。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 202,905评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,140评论 2 379
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 149,791评论 0 335
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,483评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,476评论 5 364
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,516评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,905评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,560评论 0 256
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,778评论 1 296
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,557评论 2 319
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,635评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,338评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,925评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,898评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,142评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,818评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,347评论 2 342

推荐阅读更多精彩内容