本篇内容主要讲解“mybatisplus如何更新字段为null”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“mybatisplus如何更新字段为null”吧!

mybatis plus 将字段更新为 null,默认如果不做任何处理,使用 mybatis plus 自带的更新方法是不能将字段更新为 null 的,如果要将字段更新为 null,需要做下面的处理

在需要的字段上加 @TableField 注解,并设置属性

updateStrategy = FieldStrategy.IGNORED

测试代码如下数据库表

实体类

packagecom.sbmp.bean;importjava.time.LocalDate;importcom.baomidou.mybatisplus.annotation.IdType;importcom.baomidou.mybatisplus.annotation.TableId;importlombok.Data;@DatapublicclassUserinfo{/***主键id*/@TableId(type=IdType.AUTO)privateIntegerid;/**|*姓名*/privateStringname;/***生日*/privateLocalDatebirthday;}mapper

packagecom.sbmp.mapper;importcom.baomidou.mybatisplus.core.mapper.BaseMapper;importcom.sbmp.bean.Userinfo;publicinterfaceUserinfoMapperextendsBaseMapper<Userinfo>{}controller

packagecom.sbmp.controller;importorg.springframework.beans.factory.annotation.Autowired;importorg.springframework.web.bind.annotation.RequestMapping;importorg.springframework.web.bind.annotation.RestController;importcom.sbmp.bean.Userinfo;importcom.sbmp.mapper.UserinfoMapper;@RestControllerpublicclassUserinfoController{@AutowiredprivateUserinfoMapperuserinfoMapper;@RequestMapping("/info")publicStringinfo(){Userinfoinfo=newUserinfo();info.setId(1);info.setBirthday(null);info.setName("薛宝钗");userinfoMapper.updateById(info);return"成功";}}运行测试

看能不能将薛宝钗的生日更新为空

看打印的 sql 是没有birthday = null 的拼接的,这就是默认的情况

如果想拼接birthday = null,需要在 birthday 字段上添加这个配置

@TableField(updateStrategy = FieldStrategy.IGNORED)

修改后的代码如下

packagecom.sbmp.bean;importjava.time.LocalDate;importcom.baomidou.mybatisplus.annotation.FieldStrategy;importcom.baomidou.mybatisplus.annotation.IdType;importcom.baomidou.mybatisplus.annotation.TableField;importcom.baomidou.mybatisplus.annotation.TableId;importlombok.Data;@DatapublicclassUserinfo{/***主键id*/@TableId(type=IdType.AUTO)privateIntegerid;/**|*姓名*/privateStringname;/***生日*/@TableField(updateStrategy=FieldStrategy.IGNORED)privateLocalDatebirthday;}运行测试

这次birthday = null 成功更新

@TableField 部分属性说明

看官方文档updateStrategy 处理更新的情况;同理,添加的时候使用insertStrategy;

涉及where条件处理使用whereStrategy

FieldStrategy 说明

到此,相信大家对“mybatisplus如何更新字段为null”有了更深的了解,不妨来实际操作一番吧!这里是亿速云网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!