access数据查询显示_用包装类查询数据库name显示为空,其他原样显示的解决办法...

今日做一个小案例,运用包装类封装数据库的查询结果,最后打印结果显示查询出来的name显示为空。

65881de1e06a74484e2b9a7e568452f0.png

查询结果

以下是源码:

package session_checkCode.domain;public class User {    private int id;    private String username;    private String password;    private int salary;    public int getId() {        return id;    }    public void setId(int id) {        this.id = id;    }    public String getUsername() {        return username;    }    public void setUsername(String username) {        this.username = username;    }    public String getPassword() {        return password;    }    public void setPassword(String password) {        this.password = password;    }    public int getSalary() {        return salary;    }    public void setSalary(int salary) {        this.salary = salary;    }    @Override    public String toString() {        return "User{" +                "id=" + id +                ", username='" + username + ''' +                ", password='" + password + ''' +                ", salary='" + salary + ''' +                '}';    }}
package session_checkCode.dao;import org.springframework.jdbc.core.BeanPropertyRowMapper;import org.springframework.jdbc.core.JdbcTemplate;import session_checkCode.domain.User;import session_checkCode.utils.JDBCUtils;public class userDao {    //操作数据库    //定义JdbcTemplate    private JdbcTemplate template = new JdbcTemplate(JDBCUtils.getDataSource());    //定义方法操作数据库    public User login(User loginUser){        //定义sql语句        String sql = "select * from student where name = ? and  password = ?";        User user = new User();        try{            user = template.queryForObject(sql, new BeanPropertyRowMapper(User.class),                    loginUser.getUsername(),loginUser.getPassword());        }catch(Exception e){            return null;        }        return user;    }}
package session_checkCode.test;import jdk.jfr.StackTrace;import org.junit.Test;import session_checkCode.dao.userDao;import session_checkCode.domain.User;public class DaoTest {@Testpublic void daoTest(){    User loginUser = new User();    loginUser.setUsername("zhangsan");    loginUser.setPassword("1234");    userDao ud = new userDao();    User login = ud.login(loginUser);    System.out.println(login);}}

解决问题:

原因出在了User类中变量名与数据库中的名的不对应,将private String username改为private

String name ,并将相应的getter setter方法改了,之后查询结果无误。

1a53eb957a6f8e484837811a418b922f.png

修改后的查询结果

以此记录所犯之错,以及所解之法!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值