mybatis更新字段从有值变为null

mybatisplus更新时,如果传入的值为null,对于update来说是不更新当前字段,此时对于原本有值的数据更新为null时更新不了
解决办法:

LambdaUpdateWrapper<Resource> wrapper = null;
for (ResourceToHangDto resourceToHangDto : list) {
			Resource resource = new Resource();
			//对于mybaits自带的数据库操作方法只需要将version放进要修改的实体类where条件和set的数值会自动发生改变
			resource.setVersion(resourceToHangDto.getVersion().longValue());
			resource.setStockTotalWeight(resourceToHangDto.getStockTotalWeight());
			resource.setItemPrice(resourceToHangDto.getItemPrice());
			resource.setAccountType(resourceToHangDto.getAccountType());
			wrapper = new LambdaUpdateWrapper ();
			wrapper.eq(Resource::getResourceCode, resourceToHangDto.getResourceCode());
			if (resourceToHangDto.getStockQuantity() == null){
				//库存数量为空时将库存数量更新为null
				wrapper.set(Resource::getStockQuantity, null);
			}else {
				resource.setStockQuantity(resourceToHangDto.getStockQuantity());
			}
			num += baseMapper.update(resource, wrapper);
		}

在这里插入图片描述

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值