MyBatis异常TooManyResultsException异常
今天在练习的时候出现该异常:Expected one result (or null) to be returned by selectOne(), but found: 2
原来出错代码:
java
Map<String,Object> map = recordMapper.getUserRecordByuserId(11);
```bash
改正后代码:
List<Map<String,Object>> map = recordMapper.getUserRecordByuserId(11);
原因:返回多条数据是多个Map,多个Map放在List中用List<Map<String,String>>接收返回数据
Mybatis返回的Map是这样的一种格式:Map<字段名称,字段值>
一个Map<字段名,字段值>对象代表一行数据
对该类异常可进行以下分析:
从上面的异常信息,可以了解到下面两种情况:
1.你想查询一条数据,但返回两条数据:
2.你想查询多条数据,但是前台限制只能查询一条
(1) 检查自己的数据sql语句写对没有(关于mybaties的sql操作自己百度)
(2) 查看mybaties的返回值(resultType或resultMap),可以返回list,map等数据
(3) dao层接口要与mybaties中返回值和接收值都要保持一致
例:返回map数据