Mybatis-Plus实现只更新部分字段的数据

目录
  • Mybatis-Plus只更新部分字段数据
    • 1、通过UpdateWrapper修改指定的列
    • 2、使用场景和案例
  • Mybatis-Plus更新字段问题
    • spring-boot设置
    • 属性设置有4种策略

Mybatis-Plus只更新部分字段数据

1、通过UpdateWrapper修改指定的列

update 时传入 null 是关键

重点语句:updateWrapper.set(“SESSION_KEY”, “abc”);

this.mapper.update(null, wrapperUpdate);

2、使用场景和案例

使用版本:3.0.4

UpdateWrapper updateWrapper = new UpdateWrapper();
updateWrapper.eq("id", 1);
updateWrapper.set("status",  1);
updateWrapper.set("nickname",  "张三");
baseMapper.update(null, updateWrapper);

Mybatis-Plus更新字段问题

mybatis更新为 null的对象 ,需设置 :

spring-boot设置

mybatis-plus.global-config.db-config.field-strategy=ignored

属性设置有4种策略

public enum FieldStrategy {
    IGNORED,       #忽略判断
    NOT_NULL,      #非 null 判断
    NOT_EMPTY,     # 非空判断
    DEFAULT;
 
    private FieldStrategy() {
    }
}

设置为忽略判断之后 ,用查询方法 :

public List<T> list(Wrapper<T> queryWrapper) {
    return this.baseMapper.selectList(queryWrapper);
}

则查询时候 :

SELECT id,level_code,scale,rate,interest,expire_date,factor_day,product_id,create_by,create_time,update_by,update_time,version,enable,remark FROM 表 WHERE level_code=null AND scale=null AND rate=null AND interest=null AND expire_date=null AND factor_day=null AND product_id=80 AND create_by=null AND create_time=null AND update_by=null AND update_time=null AND version=null AND enable=null AND remark=null

在mybatis-plus 3.1.2之后,fieldStrategy已被弃用 ,可以分别设置 :

selectStrategy(since 3.1.2)
updateStrategy(since 3.1.2)
insertStrategy(since 3.1.2)

官方文档 : https://mp.baomidou.com/config/#logicdeletevalue

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

(0)

相关推荐

  • Mybatis Plus select 实现只查询部分字段

    目录 Mybatis Plus select 查询部分字段 select 设置查询字段 MyBatis-Plus之select.delete 一.Mybatis-Plus之查询操作 1.查询操作常用API 2.分页查询 二.Mybatis-Plus之删除操作 1.物理删除操作常用API 2.逻辑删除 Mybatis Plus select 查询部分字段 Mybatis Plus select语句默认查询所有字段,如需要指定字段查询,则需使用 QueryWrapper的select方法. sele

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

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

  • 使用Mybatis更新时候只更新变更部分的方法

    目录 Mybatis更新时候只更新变更部分 具体可以参考以下代码 Mybatis update更新字段的使用 多个mapper方法,更新单字段 通用mapper方法,java代码控制字段 特别注意,定位字段不要加if Mybatis更新时候只更新变更部分 在更新数据库的某条记录的时候,通过我们只需要更新我们设置的字段就可以了,但是如果基于ORM映射更新,当参数传入的为一个Bean的时候,这个时候会将Bean的全部字段都更新一次. 有一个场景的如在登陆时候,如果用户登陆成功以后只想更新用户登陆的i

  • mybatis-plus update更新操作的三种方式(小结)

    目录 1.@ 根据id更新 2.@ 条件构造器作为参数进行更新 3.@ lambda构造器 mybatisplus update语句为null时没有拼接上去 1.@ 根据id更新 User user = new User(); user.setUserId(1); user.setAge(29); userMapper.updateById(user); 2.@ 条件构造器作为参数进行更新 //把名字为rhb的用户年龄更新为18,其他属性不变 UpdateWrapper<User> updat

  • Mybatis-Plus实现只更新部分字段的数据

    目录 Mybatis-Plus只更新部分字段数据 1.通过UpdateWrapper修改指定的列 2.使用场景和案例 Mybatis-Plus更新字段问题 spring-boot设置 属性设置有4种策略 Mybatis-Plus只更新部分字段数据 1.通过UpdateWrapper修改指定的列 update 时传入 null 是关键 重点语句:updateWrapper.set(“SESSION_KEY”, “abc”); this.mapper.update(null, wrapperUpda

  • 让GridView只更新某些特定的数据的方法

    1.我要显示完整的数据 2.然而我又不希望所有的数据都可以修改,只希望修改某些特定的列. 3.."GridView tasks"--"Edit columns "--把我不希望改动的列的"ReadOnly"属性设为"True"就可以啦,如图: 4.修改下UpDate的代码段,把不需要修改的字段删除掉,就可以啦

  • Java的MyBatis框架中关键的XML字段映射的配置参数详解

    properties 这些是外部化的,可替代的属性,这些属性也可以配置在典型的Java属性配置文件中,或者通过properties元素的子元素来传递.例如: <properties resource="org/mybatis/example/config.properties"> <property name="username" value="dev_user"/> <property name="pas

  • 更新text字段时出现Row size too large报错应付措施

    起因: 团购开发报告说更新时出错. 更新SQL如下: 复制代码 代码如下: UPDATE table_name d SET d.column_name='aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa' WHERE d.ID=100976; 报错信息如下: Error Code : 1118 Row si

  • MyBatis查询时属性名和字段名不一致问题的解决方法

    问题 当我们数据库中的字段和实体类中的字段不一致的时候,查询会出问题 数据库字段是 pwd id name pwd 1 张三 123456 2 李四 123456 3 王五 123456 4 赵六 123456 实体类字段是 password public class User { private int id; private String name; private String password; } 查出来结果发现, password 是 null User{id=1, name='张三

  • 使用MyBatis返回其它类对象的字段处理

    目录 MyBatis返回其它类对象的字段处理 需求 此时两种处理方式 MyBatis返回自定义字段接收 1.有时候需要查询的返回的结果不是javaBean的属性 2.DAO接口 3.后台取值 MyBatis返回其它类对象的字段处理 需求 在A.xml中联合查询A表所有字段及B表中的nikename字段,B表和A表没有关系但是和C表有关联,C表和A表有关联,其处理方式如下 1.sql先写好,比如当前只做A表所有符合条件的查询 SELECT * FROM sce_salegoods 2.取sce_u

  • mybatis自定义参数类型转换器数据库字段加密脱敏

    目录 1 问题背景 2 解决方案 2.1 使用数据库加密算法 2.2 使用mybatis的自定义参数类型转换器 3 一般web项目使用 3.1 创建自定义Java类型 3.2 自定义类的转换处理器 3.3 配置自定义类型和类型转换器 3.4 查询使用 3.5 新增修改使用 4. springboot项目使用 4.1 配置自定义类型和类型转换器 4.2 mybatis-plus的使用 1 问题背景 在数据库存储人员的信息时,有一些信息是敏感数据,如身份证号.出生地等.为了防止信息泄漏,这些信息不允

  • oracle+mybatis 使用动态Sql当插入字段不确定的情况下实现批量insert

    最近做项目遇到一个挺纠结的问题,由于业务的关系,DB的数据表无法确定,在使用过程中字段可能会增加,这样在insert时给我造成了很大的困扰. 先来看一下最终我是怎么实现的: <insert id="batchInsertLine" parameterType="HashMap"> <![CDATA[ INSERT INTO tg_fcst_lines(${lineColumn}) select result.*,sq_fcst_lines.next

随机推荐