loadrunner录制mysql_LoadRunner11_录制MySQL数据库脚本

记录一次压测过程中,通过LoadRunner向MySQL数据库插入大量数据的过程。

【1】需要使用到MySQL的libmysql.dll动态链接库,因此需要安装MySQL;注:本地安装的MySQL最好和MySQL数据库服务器上的版本一致;(本次使用的是MYSQL 5.6)

【2】LoadRunner选择“CVuser”协议;

373067adbf26939073b62eade6e33aec.png

【3】选择“File”→“Add Files to script”,将MySQL Server 5.6/lib下的libmysql.dll载入;这样载入,相比在脚本中采用绝对路径,可移植性更好;

59554ca2947e9363771cce3e078ce418.png

而后可以看到,左侧文件已被加入;

a8911c431340ee9e148c7ed9a951e693.png

【4】使用libmysql.dll中的函数,完成脚本;

【5】当Insert SQL语句含有中文时,需要设置字符集为GBK,防止中文乱码:mysql_query(db_connection,lr_eval_string("SET NAMES gbk"));

完整代码:

(1)vuser_init.c文件内容

intrc;int db_connection; //数据库连接

int query_result; //查询结果集 MYSQL_RES

char ** result_row; //查询的数据行

char *server = "*.*.*.*"; //压测数据库IP地址char *user = "test"; //压测数据库登录名char *password = "test"; //压测数据库登录密码char *database = "TESTDB"; //压测数据库名int port = 8066; //压测数据库端口号int unix_socket =NULL;int flags = 1;

vuser_init()

{//找到libmysql.dll的所在位置.如果安装了mysql,并将dll文件导入了脚本内,可以直接load,不需要路径

rc = lr_load_dll("libmysql.dll");if (rc != 0)

{

lr_error_message("Could not load libmysql.dll");

lr_abort();

}//创建MySQL对象

db_connection =mysql_init(NULL);if (db_connection ==NULL)

{

lr_error_message("Insufficient memory");

lr_abort();

}//连接到MySQL数据库

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();

}//若插入数据中含有中文,则需要设置字符集为GBK,防止中文乱码

mysql_query(db_connection,lr_eval_string("SET NAMES gbk"));return 0;

}

(2)Ation.c文件内容

Action()

{  //参数化CUS_CODE等参数;

lr_save_string(lr_eval_string("INSERT INTO `so_customer` (`ID`, `CREATOR`, `CREATE_TIME`, `UPDATE_TIME`, `VERSION`, `SYNC_VERSION`, `REMARK`, `UDF`, `CUS_NAME`, `CUS_CODE`, `CUS_PHONE`, `CUS_FAX`, `CUS_ADDRESS`, `CUS_OWNER_ID`, `CUS_OWNER_NAME`, `CUS_OPERATION_EMPLOYEE_ID`, `CUS_OPERATION_EMPLOYEE_NAME`, `SETTLE_METHOD`, `CONTACT_PERSON`, `Z_CUS_ID`, `STATUS`, `TIME`)"

"VALUES (NULL, ‘性能测试Creator‘, ‘2017-05-11 19:35:58.000000‘, ‘2017-05-11 19:35:58.000000‘, ‘25‘, ‘99990000000001‘, NULL, NULL,"

"‘{CUS_CODE}‘, ‘{CUS_CODE}‘,NULL, ‘‘, ‘‘, ‘{ID}‘, ‘{NAME}‘, NULL, ‘‘, NULL, ‘性能测试专用‘,"

"‘50000003{cus_id}‘, ‘1‘, ‘2017-05-05 19:13:55‘);"),"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();

}return 0;

}

(3)vuser_end.c文件内容

vuser_end()

{

mysql_close(db_connection);return 0;

}

备注:

①直接向数据库插入数据库,建议“Version”字段默认给1,该字段有时是乐观锁的实现方式之一,没有值可能导致服务器报“乐观锁”错误;

附录-----留存:

libmysql.dll动态链接库提供了很多函数来对数据库进行操作,大致可以分为以下几类:

函数的具体参数和使用方法也可以参考与libmysql.dll对于的头文件mysql.h

第一部分 控制类函数

mysql_init()初始化MySQL对象

mysql_options()设置连接选项

mysql_real_connect()连接到MySQL数据库

mysql_real_escape_string()将查询串合法化

mysql_query()发出一个以空字符结束的查询串

mysql_real_query()发出一个查询串

mysql_store_result()一次性传送结果

mysql_use_result()逐行传送结果

mysql_free_result()释放结果集

mysql_change_user()改变用户

mysql_select_db()改变默认数据库

mysql_debug()送出调试信息

mysql_dump_debug_info()转储调试信息

mysql_ping()测试数据库是否处于活动状态

mysql_shutdown()请求数据库SHUTDOWN

mysql_close()关闭数据库连接

第二部分 信息获取类函数

mysql_character_set_name()获取默认字符集

mysql_get_client_info()获取客户端信息

mysql_host_info()获取主机信息

mysql_get_proto_info()获取协议信息

mysql_get_server_info()获取服务器信息

mysql_info()获取部分查询语句的附加信息

mysql_stat()获取数据库状态

mysql_list_dbs()获取数据库列表

mysql_list_tables()获取数据表列表

mysql_list_fields()获取字段列表

第三部分 行列类操作函数

mysql_field_count()获取字段数

mysql_affected_rows()获取受影响的行数

mysql_insert_id()获取AUTO_INCREMENT列的ID值

mysql_num_fields()获取结果集中的字段数

mysql_field_tell()获取当前字段位置

mysql_field_seek()定位字段

mysql_fetch_field()获取当前字段

mysql_fetch_field_direct()获取指定字段

mysql_frtch_fields()获取所有字段的数组

mysql_num_rows()获取行数

mysql_fetch_lengths()获取行长度

mysql_row_tell()获取当前行位置

mysql_row_seek()行定位

mysql_da ta_seek()行定位

mysql_fetch_row()获取当前行

第四部分 线程类操作函数

mysql_list_processes()返回所有线程列表

mysql_thread_id()获取当前线程ID

mysql_thread_safe()是否支持线程方式

mysql_kill()杀列一个线程

第五部分 出错处理类函数

mysql_errno()获取错误号

mysql_error()获取错误信息

第六部分 已过时的函数

mysql_connect()

mysql_create_db()

mysql_drop_db()

mysql_eof()

mysql_reload()

mysql_escape_string()

原文:http://www.cnblogs.com/xpp142857/p/7050959.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值