如何总是更新某个字段

16 篇文章 0 订阅
4 篇文章 0 订阅

需求描述:

项目用的mybatisPlus,现在有一个字段,不管是不是空,都需要更新这个字段;

解决方法:

1.使用字段注解:
mybatis-plus FieldStrategy 有三种策略:
IGNORED0 忽略 这种情况总是会更新
NOT_NULL1NULL,默认策略
NOT_EMPTY2 非空
而默认更新策略是NOT_NULL:非 NULL;即通过接口更新数据时数据为NULL值时将不更新进数据库。

根据具体情况,在需要更新的字段中调整验证注解:
@TableField(strategy=FieldStrategy.IGNORED)
这样的话,我们只需要在需要更新为null的字段上,设置忽略策略

注意:

设置忽略这种方式,一般不太建议使用,只有在所有情况下都更新时才使用,否则有你痛苦的!!!

如果只在某些方法里需要更新空值,建议使用下面两种方式

2.自己写sql.在xml文件里写更新语句
3.使用updateWrapper

方法如下:

 UpdateWrapper< User> updateWrapper = new UpdateWrapper<>();
        updateWrapper.lambda().set(User::getName,null)
                .set(User::getAge,null)
                .eq(User::getId,po.getId());
        mapper.updateNoTenant(null,updateWrapper);
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值