关于mybatis中下下划线字段查出为null

网上有很多关于mybatis中字段有下滑线值为null的情况,虽然他们的解决方式都是正确的,能够解决问题,但是,他们找的原因都是错误的,你一定使用了逆向工程生成实体,虽然生成的实体有映射,但是真的能够映射成功嘛?我如果手动建实体就不会有这样的情况发生,那么原因就在于set上面,设置值的时候是没有设置成功的,究其原因是因为逆向工程生成的映射没有成功,所以才会赋值失败,以上是我的看法

1、配置问题

或者 

//开启驼峰映射
        bean.getObject().getConfiguration().setMapUnderscoreToCamelCase(true);

mybatis配置文件设置了这项后,查询出来的字段如果带下划线,那么就会去掉下划线,然后采用java驼峰规则。比如数据库字段Parent_id,那么查询出来后,会转为parentid,然后去实体类Category匹配对应的字段。 因为你实体类里有下划线,所以匹配不上。要么采用resultMap 要么禁用掉驼峰规则(不建议禁用)。如果不想该实体类的话,建议采用resultMap。

2、增加set方法转换值的方式

原实体类

 
  1. public class demo {

  2. private String user_name;

  3. private Striing pass_word;

  4.  
  5.  
  6. public String getPass_word(){

  7. return pass_word;

  8. }

  9. public void setPass_word(String pass_word){

  10. this.pass_word=pass_word;

  11. }

  12.  
  13. }

原sql

select user_name,pass_word from demo;

这句sql在数据库可以查到数据,但是使用mybatis的实体类查询就查不到了。

解决方法

在实体类中增加以下两个set方法并把sql改为

select user_name as username,pass_word as password from demo;

使用实体类查询数据库实际上就是一个set的过程只需要把每个属性增加一个set方法就好了

 
  1. public void setUsernaem(String user_name){

  2. this.user_name=user_name;

  3. }

  4. public void setPassword(String pass_word){

  5. this.pass_word=pass_word;

  6. }

 

你可能感兴趣的:(mybatis)