mybatis plus如何更新字段为null
本篇内容主要讲解“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”有了更深的了解,不妨来实际操作一番吧!这里是亿速云网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!
声明:本站所有文章资源内容,如无特殊说明或标注,均为采集网络资源。如若本站内容侵犯了原著者的合法权益,可联系本站删除。