总结下mp更新的几种方式,哪种会忽略null值?

直接上代码。

@SpringBootTest
public class MpUpateTest {

    @Autowired
    UserService userService;



    @Test
    public void test1() {
        //1.实体用updateById更新 发现age设为null也不更新
        User user = new User();
        user.setId(1);
        user.setName("bb");
        user.setAge(null);
        userService.updateById(user);
    }
    @Test
    public void test2() {
        //2.实体用saveOrUpdate更新 发现age设为null也不更新
        User user = new User();
        user.setId(1);
        user.setName("cc");
        user.setAge(null);
        userService.saveOrUpdate(user);
    }
    @Test
    public void test3() {
        //3.wrapper用saveOrUpdate更新  age被成功设置为了null
        UpdateWrapper<User> wrapper = new UpdateWrapper<>();
        wrapper.eq("id", 1);
        wrapper.set("name", "dd");
        wrapper.set("age", null);
        userService.update(wrapper);
    }
    @Test
    public void test4() {
        //4.LambdaUpdateWrapper用update更新 age被成功设置为了null
        LambdaUpdateWrapper<User> wrapper = Wrappers.lambdaUpdate(User.class);
        wrapper.eq(User::getId, 1);
        wrapper.set(User::getName, "ee");
        wrapper.set(User::getAge, null);
        userService.update(wrapper);
    }
}

最后做个总结。

1.当我们想要更新部分字段的时候,上述更新方法都没啥问题,只要我们不显式的设置某值为null,那就不为更新某些字段,不用担心大规模的字段为null的情况。

2.如果我们就是要设置某值为null,则只能使用wrapper 的方式,上面两种方式不会起效果。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值