最近在部署性能测试环境的时候,环境 部署好之后,部分功能出现接口查询异常,问题现象:前端
拿到错误,确定要先判断是前端仍是后端代码的问题,最简单的方式是抓包查看:java
以上是报错页面捕获的接口报错,很明显的接口已经报错了,那么就直接查看后端的日志:mysql
查看日志分两步:web
1.查看网关web端的日志:spring
从日志能够知道,出错的地方在selectOrgDetail接口查询上sql
com.xxx.postlend.debtmanagement.service.org.impl.OrgServiceImpl.selectOrgDetail(OrgServiceImpl.java:42)数据库
2.继续查看APP服务端的日志报错:apache
org.springframework.web.util.NestedServletException: Request processing failed; nested exception is org.mybatis.spring.MyBatisSystemException:后端
nested exception is org.apache.ibatis.exceptions.TooManyResultsException: Expected one result (or null) to be returned by selectOne(), but found: 2mybatis
你想查询一条数据,可是从数据库返回两条数据
看到这个错误,就知道是查询数据库的记录,查询到2条,而指望的结果是1条,即selectOne函数的查询结果,致使报错
到这个错误的缘由就是由于你的查询方法中获得两个两个结果集,然而你的返回用了一个实体去接收,程序这个时候就不知道如何去分配了,很果断的报这个错,
修改方法为使用一个list来接收就没有问题了。
其实从这个selectOne方法也能够猜出来
指望selectOne()返回一个结果(或null),但找到:2
而后我就看了下dao层的接口 是Office getOffice(id); 查的是一条数据,可结果返回的是2条数据的结果集。固然报错咯!
解决方法是将接口改成list
List<Office>getOffice(String id);
mybatis和spring整合后,dao中的接口
public Student getUser(Student userStudent);
会自动选择selectOne()方法,因为只能返回一个对象的结果,当返回到多个对象的结果集时报错。getUser是一个student类的bean没法接受多个结果集,则改用List就能够接受多个结果集
将dao中的
public Student getUser(Student userStudent);
改成
import java.util.List;
public List<Student> getUser(Student userStudent);
从日志报错的信息查看,问题出如今APP端的代码以下:
at com.xxx.postlend.debtoauth2.service.biz.impl.OrganizationServiceImpl.selectOrgDetailInfo(OrganizationServiceImpl.java:217)
经过代码查看,这个selectOne查询方式是mybatis框架的自动生成sql查询语句,因此没法查看具体的sql mapper映射文件
须要经过监控,这个接口执行的全部sql以下:
拿到上述的sql去mysql客户端工具里执行验证一下,查看是否存在主键查询出现两条记录的sql
果真发现存在2个orgId致使的报错,删除两个记录中的一个
问题完美解决
经过这个例子,其实你们在测试过程当中确定会碰见各类各样的环境问题,当出现问题的时候,首先判断问题的类型
而后经过web端仍是app端的问题,经过日志打印的堆栈,以及查看代码的方式,寻找问题的出现的缘由,这样才能慢慢的提高