今天在群里又看到了一个小伙伴问类似的问题,【jmeter如何实现数据库查询出来的结果与接口返回的结果进行对比判断,或者数据库两字段的相加减与接口返回进行对比】。其实都一样,因为你把运算放在查询那里就行了,运算放beanshell脚本里面会影响性能。这事其实很简单,来理一下思路:

1、从数据库中拿数据:用JDBC Request或beanshell后置处理器;

2、从接口返回中拿数据:用正则表达式提取器;

3、对比:用beanshell断言。

---------------------------------------------------------------------------------------------------------------------

一、数据库查询

  添加一个【JDBC Connection Configuration】先连接上数据库(具体可看jmeter连接Mysql),然后添加【JDBC Request】写SQL语句查询出所需要的数据,如下图:

若使用Beanshell PostProcess,可以这样写:

Value = vars.getObject("Result_variable_name").get().get("margin"); //从查询结果中取出margin列的第一行值,第一行index从0开始算get(0)
vars.put("result",Value); //将取出的值赋给变量result

二、接口返回

  从response中拿数据,使用正则表达式提取器,这里就不啰嗦了(可以看jmeter关联),直接放图,如下:

  上述两步完成之后,可以添加一个Debug Sampler或者其他方式看看取到的参数是否正确。如果和自己的预期有出入,那么仔细检查SQL,正则表达式等。

三、Beanshell断言

  beanshell中的代码其实是很简单的,就是一个if...else,如图:

if("${margin_1}".equals("${uid}")) //数据库的取值与接口正则取值比对
{
System.out.println("OK");
}
else
{
System.out.println("fail");
}

  数据库取到的值[margin_1]和接口返回的值[uid]进行对比,其中margin_1是指sql查询出来的第一个数据,具体用法请了解JDBC Request下面的参数,而${margin_1/uid}是jmeter调用动态参数值的方式。运行之后可以在jmeter的日志中看到结果,如下(我从数据库拿的是时间戳的相减值,接口是用户的uid,肯定是不相等的):

-----------------------------------------------------------------分割线----------------------------------------------------------

  至此,就没了。这里只阐述了数据对比这个操作,至于成功/失败之后怎么操作,就不继续说下去了,场景很多嘛。农历年前在上海的最后一篇博客,明天就请假回家啦,各位明年见。

___是非功过有人心,善恶斤两问阎王

jmeter数据库查询与接口返回进行对比的更多相关文章

  1. jmeter使用问题——将接口返回变量存储成csv文件

    在使用jmeter做接口测试时,一整个jmx测试计划中,存在多个线程,多个接口的测试 但是接口可以分类,比如业务接口.查询接口.更新接口等 考虑自动化接口测试一般都是一次性的,有完整的闭环链路,一般步 ...

  2. 【转载】jmeter将上一个接口返回值作为下一个接口的请求参数

    第一:通过JSON Extractor 插件来提取JSON响应结果 原文地址:http://blog.csdn.net/dreamtl/article/details/68957122 接口响应结果, ...

  3. 阶段5 3.微服务项目【学成在线】_day17 用户认证 Zuul_03-用户认证-认证服务查询数据库-查询用户接口-接口定义

    1.2.4 查询用户接口 完成用户中心根据账号查询用户信息接口功能. 在ucenter这个服务里面定义查询用户信息的接口 这个接口在auth的服务的loadUserByUserName这个方法里面被调 ...

  4. PHP简单获取数据库查询结果并返回JSON

    <?php header("Content-type:text/html;charset=utf-8"); //连接数据库 $con = mysql_connect(&quo ...

  5. jmeter将上一个接口返回值作为下一个接口的请求参数

    在jmeter中有时候会用到,将上一个接口的返回值作为下一个接口的请求参数 具体操作如下: 1.首先新建一个http请求(右键线程组--添加Sampler--http请求),同时添加好接口相应的请求参 ...

  6. 阶段5 3.微服务项目【学成在线】_day17 用户认证 Zuul_04-用户认证-认证服务查询数据库-查询用户接口-接口开发

    定义dao 权限放在授权的课程里面做,现在先不管.我们还需要查企业信息,就是用户所属的公司 公司表 对应关系在xc_company 这是一个关系 表 这个表里有唯一索引 user_id 所以根据use ...

  7. nodejs怎么同步从一个数据库查询函数中返回一个值

    var sql=require('msnodesql'); var conn_str="Driver={SQL Server Native Client 11.0};Server={127. ...

  8. Jmeter 从数据库查询多个字段,依次传给登录接口怎么实现?

    问题背景: 博文“Jmeter 如何把数据库的数据依次获取作为参数传入下一个请求?附栗子”某天有人留言如下: 看了下当时写的文章,如果从数据库查询多个字段,依次传给登录接口,确实不能合理实现,所以,特 ...

  9. mongodb基础系列——数据库查询数据返回前台JSP(二)

    上篇博客论述了,数据库查询数据返回前台JSP.博客中主要使用Ajax调用来显示JSON串,来获取其中某一个字段,赋给界面中的某一个控件. 那这篇博客中,我们讲解,把后台List传递JSP展示. Lis ...

随机推荐

  1. apache2.2 +php7.3安装 编译安装

    1.下载 http://archive.apache.org/dist/httpd/httpd-2.2.0.tar.gz tar -xvf httpd-2.2.0.tar.gz 2.安装 ./conf ...

  2. bzoj P5016[Snoi2017]一个简单的询问——solution

    Description 给你一个长度为N的序列ai,1≤i≤N和q组询问,每组询问读入l1,r1,l2,r2,需输出   get(l,r,x)表示计算区间[l,r]中,数字x出现了多少次. Input ...

  3. ubuntu执行sudo apt-get update 时出现的错误及解决办法

    一.错误描述 W: GPG error: http://ppa.launchpad.net/fkrull/deadsnakes/ubuntu xenial InRelease: The followi ...

  4. PeopleSoft 多套Web App Prcs交叉访问

    1.Process服务器比较简单,只需要与数据库关联,系统调用时候就会负载均衡,在PSADMIN增加服务器时候,需要选择在"主菜单>PeopleTools>进程调度器>服务 ...

  5. PGIS下载离线地图 SQLite+WPF

    项目是超高分辨率屏幕墙,实时在线加载PGIS地图速度会比较慢,造成屏幕大量留白.于是使用地图缓存,事先把这个区块的地图全部down下来,使用Sqlite数据库保存.留存. //Task taskDow ...

  6. dcloud资源升级方式更新app

    var wgtVer = null; plus.runtime.getProperty(plus.runtime.appid, function(inf) { wgtVer = inf.version ...

  7. Hadoop 客户端问题

    错误: log4j:WARN See http://logging.apache.org/log4j/1.2/faq.html#noconfig for more info.Exception in ...

  8. [iOS] 列表滑动展开隐藏头部HeaderView

    平常遇到大多数的带有列表的应用都会遇到这个场景:在列表顶端有一个Header,当向上滑动列表时,压缩header,向下滑动列表到头时,展开header.这种样式在例如微博,twitter这些展示动态的 ...

  9. LeetCode 题解之 Positions of Large Groups

    1.题目描述 2.问题分析 从头遍历字符串,使用一个局部迭代器和局部变量记录该字符个数.如果个数>= 3 ,则将此时的迭代器位置和局部迭代器的位置保存到局部vector中.再将这个局部vecto ...

  10. 七牛云A账号数据迁移到B账号下

    1,七牛云A账号下开启空间授权,可以让B账号可以访问A账号下的空间,,授予权限只读即可. 2,下载七牛云命令行工具.(通过命令完成数据迁移) https://dn-devtools.qbox.me/2 ...