mybatis-plus更新字段为null的处理方式

目录
  • mybatis-plus更新字段为null处理
    • 该如何设置?
  • mybatis-plus将字段修改为null
    • 注意事项

mybatis-plus更新字段为null处理

在mybatis-puls重设置的全局更新策略

为null的字段忽略更新。但是在某些业务需求下面,可能需要某些字段更新为null值。

该如何设置?

mybatis-plus将字段修改为null

myBatis Plus 版本3.1.2及以上

@TableField(strategy = FieldStrategy.IGNORED)
private String username;

注意事项

我们看到注解的里面**strategy**划线,已经被弃用了:

1. 下载源码,查看注解源码;

2. 看到已经有新的三种方式 insertStrategyupdateStrategywhereStrategy

3. 根据不同的操作选择不同的方式,这边业务是更新操作,就是用updateStrategy参数,即可将字段设置为null.

以上为个人经验,希望能给大家一个参考,也希望大家多多支持我们。

(0)

相关推荐

  • 解决mybatisPlus null 值更新的问题

    发现mybatisPlus会更新对象属性为null的值, 与field-strategy配置有关 mybatis-plus: global-config: db-config: field-strategy: not_null 在3.1.0版本中,其选择的值有 public enum FieldStrategy { IGNORED, NOT_NULL, NOT_EMPTY, DEFAULT; private FieldStrategy() { } } 我刚开始选择的是ignored,所以null

  • Mybatis-Plus使用updateById()、update()将字段更新为null

    目录 问题背景 问题原因 解决方案 问题背景 昨晚同事找我帮他看一个问题,他使用mybatis-plus中提供的updateById方法,想将查询结果中某个字段原本不为null的值更新为null(数据库设计允许为null),但结果该字段更新失败,执行更新方法后还是查询的结果. 问题原因 mybatis-plus FieldStrategy 有三种策略: IGNORED:0 忽略 NOT_NULL:1 非 NULL,默认策略 NOT_EMPTY:2 非空 而默认更新策略是NOT_NULL:非 NU

  • MybatisPlus 不修改全局策略和字段注解如何将字段更新为null

    mybatis-plus 以下简称mp,目前应该也算是主流的一款数据访问层应用框架.源于其对mybatis 的近乎完美的封装,让我们在使用的时候无比的顺滑, 几乎提供了所有单表操作的方法,大大提升了效率.并且这款框架还是国产的哦,没了解过的可以去了解一下. 回归正题,我们这次来讲一下,怎么样通过mp将数据库中的一个字段更新为null. 可能很多人会觉得奇怪,更新为null, 直接set field = null 不就可以了.这里大家要注意一下,一般情况,我们在使用mp的时候,他的默认策略是空不更

  • Mybatis-Plus中update()和updateById()将字段更新为null

    目录 简介 问题描述 原因 概述 源码分析 所有策略 设置为null的方案 方案1:使用UpdateWrapper更新 方案2:设置全局的field-strategy(不推荐) 方案3:设置某个字段的field-strategy 参考文章 简介 说明 本文介绍Mybatis-Plus无法将字段更新为null的原因及解决方法. 问题描述 用Mybatis-Plus的update()或者updateById()来更新数据时,无法将字段设置为null值(更新后数据还是原来的值). 原因 概述 默认情况

  • mybatis plus更新字段为null处理方法

    目录 测试代码如下 数据库表 实体类 mapper controller 运行测试 运行测试 mybatis plus 将字段更新为 null,默认如果不做任何处理,使用 mybatis plus 自带的更新方法是不能将字段更新为 null 的,如果要将字段更新为 null,需要做下面的处理 在需要的字段上加 @TableField 注解,并设置属性 updateStrategy = FieldStrategy.IGNORED 测试代码如下 数据库表 实体类 package com.sbmp.b

  • mybatis-plus更新字段为null的处理方式

    目录 mybatis-plus更新字段为null处理 该如何设置? mybatis-plus将字段修改为null 注意事项 mybatis-plus更新字段为null处理 在mybatis-puls重设置的全局更新策略 为null的字段忽略更新.但是在某些业务需求下面,可能需要某些字段更新为null值. 该如何设置? mybatis-plus将字段修改为null myBatis Plus 版本3.1.2及以上 @TableField(strategy = FieldStrategy.IGNORE

  • mybatis update更新字段的使用操作

    多个mapper方法,更新单字段 说实话不太推荐,因为如果有10个字段要更新,难道写10个方法. 但是实际中很多人都这么写. 通用mapper方法,java代码控制字段 特点是一个mapper方法包含所有字段,不为空的就update. 但是需要控制入参,一般有2中方式: new 一个对象然后set id和要改的字段 如果字段多比较费劲,需要一个一个set. 查询出对象,然后set要改的字段 这2种方式差不多,就是代码看起来不一样. 特别注意,定位字段不要加if 要更新的字段加if没有什么问题 但

  • 使用mybatis-plus想要修改某字段为null问题

    目录 mybatis-plus想要修改某字段为null 问题场景 原因 解决办法 mybatis-plus更新字段为null不生效 异常说明 原理 解决办法 总结 mybatis-plus想要修改某字段为null 问题场景 使用mybatis + mybatisPlus进行修改某字段,想要将其设为null, 但执行时没有成功. 原因 mybatis-plus会将所有为空的字段在修改时进行过滤,不进行设为空的修改操作. 解决办法 在相关字段上加上注解 @TableField(strategy =

  • 解决mybatis plus字段为null或空字符串无法保存到数据库的问题

    背景 项目中集成了mybatis plus, 今天在做后台的一个常规的增删改查时,发现字段值为null时,这个字段不会被保存到数据库 解决办法 在字段上加上 @TableField(strategy = FieldStrategy.IGNORED) strategy字段更新插入策略属性说明: IGNORED(0): "忽略判断", 所有字段都更新和插入 NOT_NULL(1): "非 NULL 判断", 只更新和插入非NULL值 NOT_EMPTY(2): &quo

  • mybatis查询到了数据,但是实体类个别字段为null问题

    目录 mybatis查询数据,实体类个别字段为null 最终的最终发现 查询的数据中有几个列为null 封装不上 sql语句查询存在的列显示不存在 问题 数据 小结一下 mybatis查询数据,实体类个别字段为null 今天在做一个简单的查询操作时遇到的坑,折腾了好久好久,有必要记录一下本菜鸡的心理活动 debug单步执行发现查询之后有几个字段没有映射成功,依然为null 而控制台打印的sql语句确实拿到了 想着是不是实体类里面的字段命名不一致,瞪大狗眼看了一万遍也没发现有啥不一样. 又试着在s

  • SpringBoot Mybatis Plus公共字段自动填充功能

    一.应用场景 平时在建对象表的时候都会有最后修改时间,最后修改人这两个字段,对于这些大部分表都有的字段,每次在新增和修改的时候都要考虑到这几个字段有没有传进去,很麻烦.mybatisPlus有一个很好的解决方案.也就是公共字段自动填充的功能.一般满足下面条件的字段就可以使用此功能: 这个字段是大部分表都会有的. 这个字段的值是固定的,或则字段值是可以在后台动态获取的. 常用的就是last_update_time,last_update_name这两个字段. 二.配置MybatisPlus 导包:

  • Mybatis plus通用字段自动填充的示例

    在进行持久层数据维护(新增或修改)的时候,我们通常需要记录一些非业务字段,比如:create_time.update_time.update_by.create_by等用来维护数据记录的创建时间.修改时间.修改人.创建人等信息.通常情况下我们需要对这些字段进行手动赋值.赋值的过程也比较冗余,都是重复操作. 通常是为create_time赋值为系统的当前时间.update_time赋值为系统修改操作执行时的当前时间. create_by(创建人).update_by(修改人)赋值为当前的登录用户的

  • 解决MyBatis中Enum字段参数解析问题

    目录 基础Class和TypeHandler 请求参数解析问题 问题解决 基础Class和TypeHandler MyBatis操作的基本User对象结构如下: @Data @Alias(value = "user") public class User implements Serializable { private static final long serialVersionUID = -4947062488310146862L; private Long id; @NotNu

  • Mybatis 批量更新实体对象方式

    目录 Mybatis批量更新实体对象 (1)Dao层接口 (2)Mapper.xml 文件 Mybatis批量更新数据三种方法效率对比 探讨批量更新数据三种写法的效率问题 Mybatis批量更新实体对象 (1)Dao层接口 /** * 根据更新采购计划(批量) * @param plans */ void batchUpdatePlan(List<PubPurchasePlan> plans); (2)Mapper.xml 文件 <sql id="batchUpdatePlan

随机推荐