mybatis延迟加载以及失效问题,总是null值的问题

 

延迟加载失败:总是提前加载完成的原因——配置,前两个一般都会配置好,最后一个如果用打印输出的方式可能会导致提前输出,配置第三项后则只要不打印改属性,就不会触发

<settings>
    <!--开启延迟加载-->
    <setting name="lazyLoadingEnabled" value="true"/>
    <!--关闭立即加载-->
    <setting name="aggressiveLazyLoading" value="false"/>
    <!--当调用配置中的方法时,加载全部的延迟加载数据。如:equals,clone,hashCode,toString-->
    <setting name="lazyLoadTriggerMethods" value="true"/>
</settings>

 

 

延迟加载的SQL语句执行总是null值的问题?

很坑,坑在于要延迟的select语句的resultType不要用,要用   resultMap="XXXResultMap"

其实你只要关闭延迟加载就能发现,不是延迟加载的问题,是自己写错了

<select id="selectStaff" parameterType="java.lang.Integer" resultType = "com.mura.db.model.Staff>
  select
  *
  from staff
  where id = #{id,jdbcType=INTEGER}
</select>

 

 

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值