Java Web 核心技术 异常及解决方案

 

目录

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异常,可捕捉该异常,根据场景,处理即可。

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值