项目场景
今天在调试项目的时候,控制台出现了如下的报错信息,从下面报错信息可以明白大致的意思是:出现了过多的结果返回值,只希望得到一个值,但是现在返回了2个。
问题描述
通过控制台打印的SQL,在数据库里面执行,显然出现两个结果返回值。
select post_id, post_code, post_name, post_sort, status, create_by, create_time, remark from sys_post where post_code = 'zongjingli';
再来看看我们定义的接口是怎样的?
SysPostMapper.java
SysPost selectPostByPostCode(String postCode);
SysPostMapper.xml
<select id="selectPostByPostCode" parameterType="String" resultMap="SysPostResult">
<include refid="selectPostVo"/>
where post_code = #{postCode}
</select>
原因分析
通过SQL查询出来的结果用于接收的是单个对象,但sql查询出来的结果却是一个列表(多个) 导致无法接收所有的查询结果值。
解决方案
下面给予了两种解决方案:
- 把Mybatis对应的mapper接口的返回值修改为List
List<SysPost> selectPostByPostCode(String postCode);
- 根据业务场景对查询SQL语句做返回数量的限制
select post_id, post_code, post_name, post_sort, status, create_by, create_time, remark from
sys_post where post_code = 'zongjingli' limit 1;