MybatisPlus查询条件空字符串和NULL问题背景分析

 更新时间:2025年03月13日 11:30:10   作者:ChrisitineTX  
文章详细分析了MybatisPlus在处理查询条件时,空字符串和NULL值的问题,MP 3.3.0及以上版本提供了多种解决方法,包括在Bean属性上使用注解、全局配置等,推荐使用全局配置的方式来解决这个问题,以避免在SQL查询中出现不必要的空字符串条件,感兴趣的朋友跟随小编一起看看吧

MybatisPlus查询条件空字符串和NULL问题背景分析

MP依赖版本

    <dependency>
        <groupId>com.baomidou</groupId>
        <artifactId>mybatis-plus</artifactId>
        <version>3.3.1.tmp</version>
    </dependency>

问题背景

在使用MP实现条件查询时,如果入参为null或者""时,则MP还是会把其当做条件去执行如图:

入参:

MP官方文档给出解决方案:https://mp.baomidou.com/config/#insertstrategy
个人建议增加全局配置:
mybatis-plus: global-config: db-config: select-strategy: not_empty

但是又出现一个新的问题,id为""时,仍然不会被QueryWrapper屏蔽掉,还是会被当做条件去查询
入参

执行语句

支持非空字段判断拼接

LambdaUpdateWrapper<Orders> wrapper = new LambdaUpdateWrapper<>();
wrapper.eq(!order.getState().sEmpty(),Orders::getState, orders.getState());

补充:MyBatis-Plus过滤查询条件中的空字符串

MyBatis-Plus过滤查询条件中的空字符串

        在使用MyBatis-Plus查询时,若封装查询条件的Bean中有属性为空字符串,是不会被过滤掉的,结果就是执行的SQL的where条件中出现某个字段="",导致查询出问题。尤其常见于,在前端页面输入该字段的查询条件后,又清空输入的关键字。

老规矩,先说MyBatis-Plus版本:3.3.0

有2种思路:

在Bean中给字段通过注解,过滤查询时的空字符串;

// value指代对应的数据表的字段名称,whereStrategy 指定查询时的过滤策略
@TableField(value = "PATIENT_NAME", whereStrategy = FieldStrategy.NOT_EMPTY)
private String patientName;

查看源码源码得知,一共有5种字段策略(5种策略也可用于INSERT或UPDATE语句),如下:

package com.baomidou.mybatisplus.annotation;
/**
 * 字段策略枚举类
 *
 * @author hubin
 * @since 2016-09-09
 */
public enum FieldStrategy {
    /**
     * 忽略判断
     */
    IGNORED,
    /**
     * 非NULL判断
     */
    NOT_NULL,
    /**
     * 非空判断(只对字符串类型字段,其他类型字段依然为非NULL判断)
     */
    NOT_EMPTY,
    /**
     * 默认的,一般只用于注解里
     * <p>1. 在全局里代表 NOT_NULL</p>
     * <p>2. 在注解里代表 跟随全局</p>
     */
    DEFAULT,
    /**
     * 不加入 SQL
     */
    NEVER
}

        2.在配置文件中,全局配置,以SpringBoot为例。(推荐)

mybatis-plus:
  global-config:
    db-config:
      select-strategy: not_empty

        更多配置可参考MyBatis-Plus官网配置介绍页面。需要注意的是,在yml配置文件中的配置,不是像官网上的驼峰命名方法。

使用配置 | MyBatis-PlusMyBatis-Plus 官方文档

到此这篇关于MybatisPlus查询条件空字符串和NULL问题背景分析的文章就介绍到这了,更多相关MybatisPlus查询条件空字符串内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Spring Cloud Gateway入门解读

    Spring Cloud Gateway入门解读

    本篇文章主要介绍了Spring Cloud Gateway入门解读,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-04-04
  • 详解Spring Data JPA动态条件查询的写法

    详解Spring Data JPA动态条件查询的写法

    本篇文章主要介绍了Spring Data JPA动态条件查询的写法 ,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-06-06
  • 聊聊SpringBoot使用Nacos进行服务注册发现与配置管理问题

    聊聊SpringBoot使用Nacos进行服务注册发现与配置管理问题

    Nacos支持基于DNS和基于RPC的服务发现(可以作为springcloud的注册中心)、动态配置服务(可以做配置中心)、动态 DNS 服务。本文重点给大家介绍SpringBoot使用Nacos进行服务注册发现与配置管理,感兴趣的朋友一起看看吧
    2022-01-01
  • SpringBoot利用Redis实现防止订单重复提交的解决方案

    SpringBoot利用Redis实现防止订单重复提交的解决方案

    在涉及订单操作的业务中,防止订单重复提交是一个常见需求,用户可能会因误操作或网络延迟而多次点击提交订单按钮,导致订单重复提交,所以本文给大家介绍了SpringBoot利用Redis实现防止订单重复提交的解决方案,需要的朋友可以参考下
    2024-10-10
  • Spring之@DependsOn注解详细解析

    Spring之@DependsOn注解详细解析

    这篇文章主要介绍了Spring之@DependsOn注解详细解析,@DependsOn注解是Spring中提供的一个指定Spring创建Bean的依赖顺序的注解,需要的朋友可以参考下
    2024-01-01
  • Java中的内存模型(JMM)和锁机制详解

    Java中的内存模型(JMM)和锁机制详解

    这篇文章主要介绍了Java中的内存模型(JMM)和锁机制使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2025-06-06
  • 解决Maven项目pom.xml导入了Junit包还是用不了@Test注解问题

    解决Maven项目pom.xml导入了Junit包还是用不了@Test注解问题

    在Maven项目中,如果在非test目录下使用@Test注解,可能会因为pom.xml中<scope>test</scope>的设置而无法使用,正确做法是将测试代码放在src/test/java目录下,或去除<scope>test</scope>限制,这样可以确保Junit依赖正确加载并应用于适当的代码部分
    2024-10-10
  • Java线程通信详解

    Java线程通信详解

    本篇文章主要介绍了Java线程通信问题,线程通信用来保证线程协调运行,有需要的朋友可以了解一下。
    2016-10-10
  • Java Socket编程实现群聊实践案例

    Java Socket编程实现群聊实践案例

    本文介绍了如何实现特定客户端与特定客户端之间的私聊和群聊功能,通过服务器端的多线程处理和客户端的Socket连接,实现了消息的路由和转发,本文给大家介绍Java Socket编程实现群聊功能,感兴趣的朋友跟随小编一起看看吧
    2025-12-12
  • java中的connection reset 异常处理分析

    java中的connection reset 异常处理分析

    本文主要介绍了java中的connection reset 异常处理分析的相关资料,具有很好的参考价值。下面跟着小编一起来看下吧
    2017-04-04

最新评论