关于Expected one result (or null) to be returned by selectOne(), but found: 3。。。。异常

本人找了几个小时


如下:

- (13243 ms) - 2017-9-20 00:03:28[DEBUG](FrameworkServlet.java:976) Could not complete request
org.mybatis.spring.MyBatisSystemException: nested exception is org.apache.ibatis.exceptions.TooManyResultsException: Expected one result (or null) to be returned by selectOne(), but found: 2
    at org.mybatis.spring.MyBatisExceptionTranslator.translateExceptionIfPossible(MyBatisExceptionTranslator.java:73)
    at org.mybatis.spring.SqlSessionTemplate$SqlSessionInterceptor.invoke(SqlSessionTemplate.java:364)



看看加红的代码,不是网上说的这个样,这样解决不了:如下----

看到标题就已经很明了了:

两种情况:

1.你想查询一条数据,但返回两条数据:

2.你想查询多条数据,但是前台限制只能查询一条

(1) 检查自己的数据sql语句写对没有(关于mybaties的sql操作自己百度)

(2) 查看mybaties的返回值(resultType或resultMap),可以返回list,map等数据

(3)  dao层接口要与mybaties中返回值和接收值都要保持一致

例:返回map数据


返回多条数据是多个Map,多个Map放在List中用List<Map<String,String>>接收返回数据

Mybatis返回的Map是这样的一种格式:Map<字段名称,字段值> 

一个Map<字段名,字段值>对象代表一行数据


其实是很简单的问题,那就是数据库,你的账户同字段的有多个,肯定登录不了关于Expected one result (or null) to be returned by selectOne(), but found: 3。。。。异常



关于Expected one result (or null) to be returned by selectOne(), but found: 3。。。。异常关于Expected one result (or null) to be returned by selectOne(), but found: 3。。。。异常