目录
EmptyResultDataAccessException
1、EmptyResultDataAccessException
在前端表单检测用户输入的用户名是否可用时,遇到了这个异常。
场景回忆:
用户输入用户名时,需要检测用户名在数据库中是否存在。
不存在,则给用户提示:“用户名可用”;
存在 ,则需要提示:“用户名已存在,不可用”。
按用户名查找检索数据库时,用template调用queryForObject方法
就在用template调用queryForObject方法时,报出该异常:
//sql
String sql="select * from user where username=?";
//调用方法
user = template.queryForObject(sql, new BeanPropertyRowMapper<User>(User.class), name);
//异常
org.springframework.dao.EmptyResultDataAccessException:
Incorrect result size: expected 1, actual 0
解决方案:
把这个异常抓一下,让其返回null,表示数据库中没有该对象,接下来可以在Servlet中对前端用户的输入作出响应,提示用户:用户名可用。
demo如下:
//操作数据库的DAO
public class UserDaoImpl implements UserDao {
JdbcTemplate template=new JdbcTemplate(JDBCUtils.getDataSource());
@Override
public User findUserByName(String name) {
User user=null;
String sql="select * from user where username=?";
try {
//当没有找到对应的user时,会抛出EmptyResultDataAccessException 异常
//解决方法是:把这个异常抓一下,让结果返回null
user = template.queryForObject(sql, new BeanPropertyRowMapper<User>(User.class), name);
} catch (DataAccessException e) {
return null;
}
return user;
}
}
//Servlet代码片段
UserService userService = new UserServiceImpl();
//在service的findUserByName方法中调用dao中的findUserByName方法
User userDB = userService.findUserByName(username);
Map<String,Object> map=new HashMap<String,Object>();
//在DB中未找到用户,则用户名可用
if(userDB==null){
map.put("UserExsit",false);//把响应信息写入map
map.put("msg","用户名可用");
}else if(username.equals(userDB.getUsername())){
map.put("UserExsit",true);
map.put("msg","此用户名太受欢迎,请更换一个");
}
解决方案形成过程:
调试看queryForObject源码
public <T> T queryForObject(String sql, RowMapper<T> rowMapper, Object... args) throws DataAccessException {
List<T> results = (List)this.query((String)sql, (Object[])args, (ResultSetExtractor)(new RowMapperResultSetExtractor(rowMapper, 1)));
return DataAccessUtils.requiredSingleResult(results);
}
继续看:DataAccessUtils.requiredSingleResult(results)
public static <T> T requiredSingleResult(Collection<T> results) throws IncorrectResultSizeDataAccessException {
int size = results != null ? results.size() : 0;
if (size == 0) {
throw new EmptyResultDataAccessException(1);
} else if (results.size() > 1) {
throw new IncorrectResultSizeDataAccessException(1, size);
} else {
return results.iterator().next();
}
}
这里需要注意,从源码可以看出,如果size为0,表示集合为空,则会抛出EmptyResultDataAccessException异常【Incorrect result size: expected 1, actual 0】。
//如果 Collection 集合空,则 size 为0
int size = results != null ? results.size() : 0;
if (size == 0) {
//抛出异常
throw new EmptyResultDataAccessException(1);
}
拓展:
if (results.size() > 1) {
throw new IncorrectResultSizeDataAccessException(1, size);
}
如果size>1则表示,数据库中有多个同用户名对象,会抛出IncorrectResultSizeDataAccessException异常【Incorrect result size: expected 1, actual size】。
总结:
如果没有找到想找的记录,则会报EmptyResultDataAccessException异常
如果DB中有多个同指明字段的记录,则会报IncorrectResultSizeDataAccessException异常
为了解决EmptyResultDataAccessException异常,可捕捉该异常,根据场景,处理即可。