LR11直接对数据库访问操作方法在性能测试中的应用总结
项目背景概述
某测试项目,该项目的接口测试需要大量的订单,并且需要订单的状态是已确认客户的订单,大量的订单可以通过下单接口直接造订单数据,但下的订单要人工在后台页面处理到已确认客户的状态才可以使用这些订单数据,大量订单人工处理到已确认客户状态,操作起来不太靠谱,后来从开发那了解到,订单从开始处理到已确认客户,主要会调用几个sp和sql的操作便可以完成, LR11提供了对数据库的直接访问和执行sp和sql的方法 ,可以使用 LR11通过模拟多线程的方式来批量的处理大量的订单到已确认客户的状态,从而可以方便高效的制造测试数据;
LR11对数据库的测试,主要使用到LR11提供的如下方法:
lr_db_connect();//建立同数据库的连接访问;
lr_db_executeSQLStatement();//执行具体的sql操作(select,update,insert,delete)或sp存储过程操作,
lr_db_disconnect();//断开数据库的连接;
需要注意的是LR11提供的对数据库的这些操作方法的使用是需要在 LR的Web Services协议脚本中才可以使用的;
具体的使用后面实例中会展现,该项目中数据的制造准备主要是通过如下过程完成
- 首先通过调用下单接口完成订单数据的制造;
测试环境获取下单接口调用地址:
http://XXX.com/XXXX.Booking.API/SaveOrderService.asmx?wsdl
具体请求使用的报文可以让开发人员提供具体的报文,报文比较长在此省略;
- 对生成的订单通过调用相关SP和Sql语句直接批量操作完成订单的处理到已确认客户;
本次项目造数据的关键步骤为处理订单到已确认客户操作,主要涉及两个SP:xxx..sp1_xxx_firstdealorder和sp2_xxx_AutoConfirmClient,两个update操作;
具体LR11调用SP和Update操作的 脚本如下:
Action()
{ //数据库的连接有如下两种方式,目前测试环境连接测试库使用的都是第一种方式//
//////数据库访问连接///// windows 认证方式的连接登录///
lr_db_connect("StepName=DatabaseConnection",
"ConnectionString=Data Source=xxxdb.test.xx.com,55666;Integrated Security=SSPI;Initial Catalog=XXXOrderDB",
"ConnectionName=XXXOrderDB",
"ConnectionType=SQL",
LAST );
//////数据库访问连接///// SQL server认证方式的连接登录参照如下//
/* lr_db_connect("StepName=DatabaseConnection",
"ConnectionString=Data Source=192.168.1.2;Initial Catalog=DataBase;User ID=User_temp;Password=******", //访问数据库的用户名和密码
"ConnectionName=ATDataBase",
"ConnectionType=SQL",
LAST );
*/
///执行存储过程///
//模拟后台中点开始处理订单的sp操作
lr_db_executeSQLStatement("StepName=StartDeal",
"ConnectionName=XXXOrderDB",
"SQLStatement=exec XXXorderdb..sp1_XXX_firstdealorder"
" @orderid='{ID}',"
"@operator='mazj',"
"@ProcessType = 'NOR',"
"@CorpConfirmType = '',"
"@CorporationID = NULL,"
"@BOS=NULL",
"DatasetName=testDataset",
LAST );
///执行update ///
//更新RecordNo记录号//
lr_db_executeSQLStatement("StepName=UpdateRecord",
"ConnectionName=XXXOrderDB",
"SQLStatement=update XXXOrderDB.dbo.O_XXX set RecordNo='AA{Param}' where OrderID = {ID};",
"DatasetName=testDataset",
LAST );
//更新processstatus状态//
lr_db_executeSQLStatement("StepName=Updatestatus",
"ConnectionName=XXXOrderDB",
"SQLStatement=update XXXOrderDB.dbo.o_orders set processstatus = (processstatus | 1) where orderid={ID};",
"DatasetName=testDataset",
LAST );
///执行存储过程///
//模拟前台页面自动确认客户的sp//
lr_db_executeSQLStatement("StepName=orderConfirm",
"ConnectionName=XXXOrderDB",
"SQLStatement=sp2_XXX_AutoConfirmClient @OrderID ='{ID}', @Eid='System'",
"DatasetName=testDataset",
LAST );
//关闭连接//
lr_db_disconnect("StepName=Disconnect",
"ConnectionName=XXXOrderDB",
LAST );
return 0;
}
脚本设计好后放入LR的Controller场景中即可对批量的订单使用多线程的方式快速的把所有的订单处理到已确认客户的状态,比起人工操作迅速千倍;
如果lr_db_executeSQLStatement()执行的是查询操作并有dataset的结果返回的话,需要在dataset使用后进行内存释放,处理查询结果集的方法:lr_db_dataset_action();方法中的Action取值为reset时表示重置指针返回第一行,取值为remove表示释放dataset占用的内存,取值print表示在回放日志中打印;
除了使用这种方式来使用LR快速制造数据外,LR11对数据库这种操作更多的是应用在对SQL语句和SP存储过程的性能测试验证方面,可以通过这种方式直接测试SQL和SP存储过程的性能。
(文中部分敏感内容的表述使用XXX代替)
LR11直接对数据库访问操作方法在性能测试中的应用总结的更多相关文章
- C#-数据库访问技术 ado.net——创建 数据库连接类 与 数据库操作方法 以及简单的数据的添加、删除、修改、查看
数据库访问技术 ado.net 将数据库中的数据,提取到内存中,展示给用户看还可以将内存中的数据写入数据库中去 并不是唯一的数据库访问技术,但是它是最底层的数据库访问技术 1.创建数据库,并设置主外键 ...
- SpringBoot数据库访问(一)--------关系型数据库访问(RDBMS)
关系型数据库访问(RDBMS) 采用JdbcTemplate.MyBatis.JPA.Hibernate等技术. 一.JdbcTemplate工具 在pom.xml添加boot-starter-jdb ...
- R的数据库访问-MySQL
目录 1 RMySQL 2 环境与安装 3 建立通信 1 RMySQL R作为一款数据分析的工具,,而MySQL是一款常用的开源关系型数据库软件,非常适用于中小型的数据存储,当二者相互结合时才能爆发出 ...
- 第7章 数据库访问与ORM 慕课网微信小程序开发学习笔记
第7章 数据库访问与ORM https://coding.imooc.com/learn/list/97.html 目录: 7-1 数据库操作三种方式之原生SQL 19:09 7-2 从一个错误了解E ...
- [入门级] visual studio 2010 mvc4开发,用ibatis作为数据库访问媒介(一)
[入门级] visual studio 2010 mvc4开发,用ibatis作为数据库访问媒介(一) Date 周二 06 一月 2015 By 钟谢伟 Tags mvc4 / asp.net 示 ...
- DataAccess通用数据库访问类,简单易用,功能强悍
以下是我编写的DataAccess通用数据库访问类,简单易用,支持:内联式创建多个参数.支持多事务提交.支持参数复用.支持更换数据库类型,希望能帮到大家,若需支持查出来后转换成实体,可以自行扩展dat ...
- 在数据库访问项目中使用微软企业库Enterprise Library,实现多种数据库的支持
在我们开发很多项目中,数据访问都是必不可少的,有的需要访问Oracle.SQLServer.Mysql这些常规的数据库,也有可能访问SQLite.Access,或者一些我们可能不常用的PostgreS ...
- [开源].NET数据库访问框架Chloe.ORM
扯淡 13年毕业之际,进入第一家公司实习,接触了 EntityFramework,当时就觉得这东西太牛了,访问数据库都可以做得这么轻松.优雅!毕竟那时还年轻,没见过世面.工作之前为了拿个实习机会混个工 ...
- 我的基于asp.net mvc5 +mysql+dapper+easyui 的Web开发框架(1)数据库访问(0)
一.数据库访问 概述 1. 数据库使用mysql,orm采用dapper框架.dapper框架应用简单,只是需要自己手写sql语句,但是对于像我这样写了多年sql语句的人来说,这应该不算问题,个人还是 ...
随机推荐
- [译]HIPAA要求的SSL/TLS等级
原文链接:https://luxsci.com/blog/level-ssl-tls-required-hipaa.html 原文发表时间:2015.1.13 本博文仅仅是上述原文的翻译,仅供研究参考 ...
- 奇异值分解(SVD)详解
在网上看到有很多文章介绍SVD的,讲的也都不错,但是感觉还是有需要补充的,特别是关于矩阵和映射之间的对应关系.前段时间看了国外的一篇文章,叫A Singularly Valuable Decompos ...
- bzoj 4570 妖怪
bzoj 4570 妖怪 正解应该是 \(O(nlogn)\) 的凸包,但被我的 \(O(100n)\) 的三分水过去了. 记 $x=\frac b a $ ,显然有 \(strength_i=ATK ...
- 如何将常规的web 应用程序转化为云上多租户 SaaS 解决方案
如何将web 应用程序转化为多租户 SaaS 解决方案 https://www.ibm.com/developerworks/cn/cloud/library/cl-multitenantsaas/i ...
- 细说VS MSBuild 和 Framework 的区别
如今已经是 VS2017 横行的时代,而据我所知,大部分人还停留在使用 VS2015 VS2013 或更低的版本,主要是因为他们参与的项目基本使用这几个VS的版本开发的.眼红VS2017却不敢升级,主 ...
- nginx fastcgi 优化
fastcgi_cache_path /usr/local/nginx/fastcgi_cache levels=1:2 keys_zone=TEST:10m inactive=5m; fastcgi ...
- FastAdmin 关于跨域问题解决
FastAdmin 关于跨域问题解决 之前很久之前收集到社区的问题. https://forum.fastadmin.net/thread/277 今天又有人问到,无法打开,估计是网络问题. 以下为完 ...
- Mongodb简单介绍安装
具体详细内容,请查阅 Mongodb官方文档 一.简单介绍 MongoDB 是由C++语言编写的,是一个基于分布式文件存储的开源数据库系统. 在高负载的情况下,添加更多的节点,可以保证服务器性能. M ...
- new String(tmp,1,nlen,"UTF8")
tmp是一个byte(字节)数组,如:['a','b','c'...],tmp[0]是去byte中的第一个,运算符&表示按位运算‘且’,就是前后值的二进制相同位有0取0,否则取1,如:2&am ...
- php 实现四种排序两种查找
function bubbleSort($arr){ $len = count($arr); if($len<=1) { return $arr; } for ($i=0;$i<$len; ...