Mybatis中updateByPrimaryKeySelective和updateByPrimaryKey区别

摘自: https://blog.csdn.net/a670941001/article/details/54619432

 

  • int updateByPrimaryKeySelective(TbItem record);
  • int updateByPrimaryKey(TbItem record);

 

updateByPrimaryKeySelective会对字段进行判断再更新(如果为Null就忽略更新),如果你只想更新某一字段,可以用这个方法。

 

updateByPrimaryKeySelective是逆转工程生成的Mapper接口

对应的xml为

<update id="updateByPrimaryKeySelective" parameterType="com.taotao.pojo.TbItem">
update tb_item
<set>
<if test="title != null">
title = #{title,jdbcType=VARCHAR},
</if>
</set>
where id = #{id,jdbcType=BIGINT}
</update>


 

 

updateByPrimaryKey对你注入的字段全部更新 

<update id="updateByPrimaryKey" parameterType="com.taotao.pojo.TbItem">
update tb_item
set title = #{title,jdbcType=VARCHAR},
where id = #{id,jdbcType=BIGINT}
</update>

  

 

上一篇:mybatis insert 插入多条数据


下一篇:使用Mybatis-plus更新null字段的解决方案