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

发布于 2021-07-05  2.51k 次阅读


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")即可。

<resultMap id="BaseResultMap" type="cn.edu.zzuli.bean.Goods">
<id column="goods_id" property="goodsId" jdbcType="INTEGER"/>
<result column="goods_name" property="goodsName" jdbcType="VARCHAR"/>
<result column="sh_id" property="shId" jdbcType="INTEGER"/>
<result column="sales" property="sales" jdbcType="INTEGER"/>
<result column="price_refer" property="priceRefer" jdbcType="DOUBLE"/>
<result column="price" property="price" jdbcType="DOUBLE"/>
<result column="stock" property="stock" jdbcType="INTEGER"/>
</resultMap>
我猜想:应该是resultType对小写驼峰命名法和数据库的下划线命名法适应的不太好,才会出现这个问题。
当然有人如果知道答案,希望可以在评论留言,一起学习一起进步。

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

转载过来供大家参考。

<resultMap id="BaseResultMap" type="com.trhui.ebook.dao.model.MerchantUser">
<id column="MU_ID" jdbcType="BIGINT" property="muId"/>
<result column="USER_ID" jdbcType="BIGINT" property="userId"/>
<result column="MERCHANT_NO" jdbcType="VARCHAR" property="merchantNo"/>
<result column="USER_PHONE" jdbcType="VARCHAR" property="userPhone"/>
<result column="GRANTED" jdbcType="VARCHAR" property="granted"/>
<result column="CREATE_DATE" jdbcType="TIMESTAMP" property="createDate"/>
<result column="MERCHANT_USER_ID" jdbcType="VARCHAR" property="merchantUserId"/>
<result column="STATUS" jdbcType="VARCHAR" property="status"/>
<result column="ENTE_USER_NO" jdbcType="VARCHAR" property="enteUserNo"></result>
</resultMap>

<sql id="Base_Column_List">
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
</sql>
<select id="selectByPrimaryKey" parameterType="java.lang.Long" resultMap="BaseResultMap">
select
<include refid="Base_Column_List"/>
from merchant_user
where MU_ID = #{muId,jdbcType=BIGINT}
</select>
如果返回的对象是resultMap 那么就不要给字段加别名了,问题就是出在这里,将字段别名去了就OK;

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

而不是返回resultMap="BaseResultMap"

 

补充:也可能是使用了Mabatis - Plus 而没有表示主键!https://blog.csdn.net/YiWangJiuShiXingFu/article/details/108378299

 

一、原因
mybatis_plus 默认会使用 “id” 为主键字段,如果数据库的主键字段不是“id”的话,使用mybatis-plus中的 selectById ,getById 方法查询数据是查询不出来的

二、解决
在实体类的主键字段加上@TableId(value =“数据库你的主键字段”)注解即可
例如我的是product_id为主键。


她喜欢所以就做咯