Mybatis查询语句返回的对象中部分字段为null(空) | 您所在的位置:网站首页 › mybatisplus返回map取消空值过滤 › 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 select from merchant_user where MU_ID = #{muId,jdbcType=BIGINT}如果返回的对象是resultMap 那么就不要给字段加别名了,问题就是出在这里,将字段别名去了就OK; 如果要给字段加别名,那么你就直接返回该对象就好了,路径要写全,如:resultType="com.trhui.ebook.dao.model.MerchantUser" 而不是返回resultMap="BaseResultMap" |
今日新闻 |
推荐新闻 |
专题文章 |
CopyRight 2018-2019 实验室设备网 版权所有 |