Mybatis查询语句返回的对象中部分字段为null(空)

sql是正确的,但是商品这个对象只有price(价格),stock(存量)是有值的,其他的都没有.

我自己的解决办法是:不使用resultType(问题很多),而是使用resultMap.

下面是我的应用场景和解决思路.

/**
 * 商品
 */
public class Goods {
    /**
     * 商品id
     */
    private Integer goodsId;
    /**
     * 商品名称
     */
    private String goodsName;
    /**
     * 商品所属商店的id
     */
    private Integer shId;
    /**
     * 商品销量
     */
    private Integer sales;
    /**
     * 商品参考价格
     */
    private Double priceRefer;
    /**
     * 价格
     */
    private Double price;
    /**
     * 库存量
     */
    private Integer stock;

    /**
     * 商品的状态吗
     */
    private GoodsEnum goodsEnum;
    //getter,setter
}
 "goodsId": null,
        "goodsName": null,
        "shId": null,
        "sales": 1,
        "priceRefer": null,
        "price": 9.9,
        "stock": 1,
        "goodsEnum": null

首先,查出来结果了,并且sql语句没有报错,排除数据库层没有查出来结果。

查看相关的逻辑代码后进行debug,定位错误位置在Mybatis的返回值问题上.

然后在百度的启发下,发现,对象中有值的属性都在数据库中对应的列名中没有"_",所有为null的列名中都包含下划线.

然后发现自己使用的是ResultType="cn.edu.bean.Goods",于是改成我写好的一个映射resultMap(resultMap="BaseResultMap")即可。


        
        
        
        
        
        
        
    
我猜想:应该是resultType对小写驼峰命名法和数据库的下划线命名法适应的不太好,才会出现这个问题。

当然有人如果知道答案,希望可以在评论留言,一起学习一起进步。

.当然也有可能是以下这种情况:sql语句中使用了别名机制,导致mybatis没有办法区分那个是对的(猜测)。

转载过来供大家参考。

 
      
      
      
      
      
      
      
      
      
  
 
  
    MU_ID muId,
    USER_ID userId,
    MERCHANT_NO merchantNo,
    USER_PHONE userPhone,
    GRANTED granted,
    CREATE_DATE createDate,
    MERCHANT_USER_ID merchantUserId,
    ENTE_USER_NO enteUserNo,
    STATUS status
  
  

如果返回的对象是resultMap 那么就不要给字段加别名了,问题就是出在这里,将字段别名去了就OK;

如果要给字段加别名,那么你就直接返回该对象就好了,路径要写全,如:resultType="com.trhui.ebook.dao.model.MerchantUser"

而不是返回resultMap="BaseResultMap"

你可能感兴趣的:(小项目和项目经验)