Incorrect result size: expected 1, actual 0异常——queryForObject报错问题

之前遇到一个问题,用JDBCTemplate写的东西总会提示Incorrect result size: expected 1, actual 0这个错误。
怎么说呢,template.queryForObject()这个方法是返回的必须是一个仅限一个结果!
但是你用实体类去接收的时候,对于刚注册的用户用户名肯定是不重复的,希望返回一个null,再继续进行下面的操作,但是这个东西不会给你返回一个空值,而是直接给你一个如标题所示的错误。

 String sql="select * from tab_user where username = ?";
user=template.queryForObject(sql,new BeanPropertyRowMapper<User>(User.class),username);

想了个办法说用queryFoeList去接收,

template.queryForList(sql,new BeanPropertyRowMapper<User>(User.class),username);

但是获取元素的时候又报错,index 0,get 0,真是难搞。
这时候我们应该用try-catch语句将其捕捉起来,这样就不会出现问题了。

public User findByUsername(String username) {
        User user=null;
        //创建sql
        try{
            String sql="select * from tab_user where username = ?";
            user=template.queryForObject(sql,new BeanPropertyRowMapper<User>(User.class),username);
        }catch (Exception e){
        
        }
        return user;
    
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值