New_ Rookie 2024-05-03 17:21 采纳率: 50%
浏览 5
已结题

template.queryForObject()总是报错

template.queryForObject()总是报错,数据库并无问题(无重复用户),前端数据也传到了后端,就是卡在了这里,试过了try catch ,并没有解决。
报错:Incorrect result size: expected 1, actual 0

img

img

img

img

  • 写回答

3条回答 默认 最新

  • 专家-赤兔[在线] 全栈领域优质创作者 2024-05-03 17:21
    关注

    引自免费微信小程序:皆我百晓生

    看起来你在尝试使用Spring框架的JdbcTemplate进行SQL查询,并且期望返回单个对象。然而,你遇到了EmptyResultDataAccessException异常,这表明查询结果数量与预期不符,预期是1条记录,但实际上返回的是0条记录。

    根据你提供的信息,问题可能出在以下几个方面:

    1. 数据库查询条件不匹配:检查用户名和密码是否对应数据库中存在的用户。
    2. SQL语句错误:确认SQL查询语句没有语法错误。
    3. RowMapper问题:确保BeanPropertyRowMapper配置正确。

    首先,我们来分析一下代码:

    @Override 
    public User Login(String name, String password){
        System.out.println("name====="+name+ " password====="+password);
        return template.queryForobject("select * from user where name=? and password=?", 
            new BeanPropertyRowMapper<>(User.class),name,password);
        // 这一行代码在这里实际上不会执行,因为前面已经有一个return语句
        return template.queryForobject(sql:"select id,name,password,role,image from user where name=?and password=?",new BeanPropertyRowMapper<>(User.class), 
            name, password); 
    }
    

    由于存在两个返回语句,只有第一个会被执行。你应该删除其中一个,保留正确的SQL查询语句。

    然后,我们需要检查登录名和密码是否匹配数据库中的记录。为了调试,可以添加一些日志输出,以便更好地了解查询过程:

    @Override 
    public User Login(String name, String password){
        System.out.println("name====="+name+ " password====="+password);
    
        String sql = "select id,name,password,role,image from user where name=? and password ?";
        logger.info("Executing SQL: {}", sql);
        logger.info("Parameters: {}, {}", name, password);
    
        try {
            return template.queryForObject(sql, new Object[]{name, password}, new BeanPropertyRowMapper<>(User.class));
        } catch (EmptyResultDataAccessException e) {
            logger.error("No user found with login name {} and password {}", name, password, e);
            throw e;
        }
    }
    

    在这个修改后的版本中,我们使用了logger.info打印SQL语句和参数,以便于查看是否与预期一致。同时,我们将queryForobject方法放在一个try-catch块中,这样当发生EmptyResultDataAccessException时,我们可以捕获并记录错误信息。

    接下来,你需要在控制台查看这些日志信息,确认SQL语句是否正确执行,以及传递给它的参数是否匹配数据库中的记录。如果还是无法找到问题,那么可能是RowMapper的问题,但根据你提供的信息,这应该不是主要问题。

    如果问题仍然存在,请提供执行的SQL语句、传递的参数以及相应的日志输出,以便我能进一步帮助你排查问题。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
查看更多回答(2条)

报告相同问题?

问题事件

  • 系统已结题 5月11日
  • 已采纳回答 5月3日
  • 创建了问题 5月3日

悬赏问题

  • ¥15 如何让企业微信机器人实现消息汇总整合
  • ¥50 关于#ui#的问题:做yolov8的ui界面出现的问题
  • ¥15 如何用Python爬取各高校教师公开的教育和工作经历
  • ¥15 TLE9879QXA40 电机驱动
  • ¥20 对于工程问题的非线性数学模型进行线性化
  • ¥15 Mirare PLUS 进行密钥认证?(详解)
  • ¥15 物体双站RCS和其组成阵列后的双站RCS关系验证
  • ¥20 想用ollama做一个自己的AI数据库
  • ¥15 关于qualoth编辑及缝合服装领子的问题解决方案探寻
  • ¥15 请问怎么才能复现这样的图呀