Mybatis中updateByPrimaryKeySelective和updateByPrimaryKey insert和insertSelective区别

本文介绍了MyBatis中两种更新操作方法:updateByPrimaryKeySelective与updateByPrimaryKey的区别与应用场景。updateByPrimaryKeySelective方法会在更新前对字段进行判断,仅更新非空字段;而updateByPrimaryKey则会更新所有字段,不论其是否为空。此外,还对比了insert与insertSelective方法的差异。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >


  • return productInfoMapper.updateByPrimaryKey(productInfo) > 0 ? true : false;
  • return productInfoMapper.updateByPrimaryKeySelective(productInfo) > 0 ? true : false;

上面的是逆转工程生成的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>
<update id="updateByPrimaryKey" parameterType="com.taotao.pojo.TbItem">
update tb_item
set title = #{title,jdbcType=VARCHAR},
where id = #{id,jdbcType=BIGINT}
</update>

区别:

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

updateByPrimaryKey对你注入的字段全部更新(不判断是否为Null)

这两个update都是使用generator生成的mapper.xml文件中,对dao层的更新操作

详细可以查看generator生成的源代码!

insert和insertSelective和上面类似,

insert:把所有值插入,但是要注意加入数据库字段有default,default是不会起作用的

insertSelective:只会插入有值的数据,并且不会忽略数据库字段有default的


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值