QueryWrapper中查询的坑及解决

 更新时间:2022年01月11日 10:27:37   作者:香猪脚  
这篇文章主要介绍了QueryWrapper中查询的坑及解决方案,具有很好的参考价值,希望对大家有所帮助。

QueryWrapper中查询的坑

首先,先看代码示例

List<Entity> list = testService.list(
                    new LambdaQueryWrapper<Entity>()
                            .eq(ObjectUtils.isNotEmpty(req.getParam()),Entity::getParam,
                                    req.getParam().substring(0,7).replace("-",""))
);

正常逻辑,当ObjectUtils.isNotEmpty(req.getParam())为false的时候,所执行的SQL不会出现当前条件的字段;

然而,这种写法如果当req.getParam()为""的时候,程序会出现数组下标越界的错误,虽然前面条件未成立,但是后面的代码依然编译执行;

此处是本猿自己工作中遇到的一些小问题,发表出来,以便记录,也给路过的伙伴提个醒。

QueryWrapper的查询方法

  • Wrapper: 条件构造抽象类,最顶端父类
  • AbstractWrapper: 用于查询条件封装,生成 sql 的 where 条件
  • QueryWrapper: Entity 对象封装操作类,不是用lambda语法
  • UpdateWrapper: Update 条件封装,用于Entity对象更新操作
  • AbstractLambdaWrapper: Lambda 语法使用 Wrapper统一处理解析 lambda 获取 column。
  • LambdaQueryWrapper: 看名称也能明白就是用于Lambda语法使用的查询Wrapper
  • LambdaUpdateWrapper: Lambda 更新封装Wrapper

QueryWrapper

@Test
    public void squery() {
        //创建QueryWrapper 对象
        QueryWrapper<User> queryWrapper = new QueryWrapper<>();
        //ge gt le lt: 大于等于 大于 小于等于 小于
        queryWrapper.ge("age",29);
        List<User> users = userMapper.selectList(queryWrapper);
        System.out.println(users);
        
        //eq ne  等于 不等于
        //between 介于查询
        queryWrapper.between("age",28,30);
        List<User> users1 = userMapper.selectList(queryWrapper);
        System.out.println(users1);
        
        //模糊查询
        queryWrapper.like("nam","l");
        queryWrapper.select("id","nam");
        List<User> users2 = userMapper.selectList(queryWrapper);
        System.out.println(users2);
        
        // orderByDesc 降序查找
        queryWrapper.orderByDesc;
        
        //last 在sql语句后面拼接
        queryWrapper.last("limit 1");
    }

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

相关文章

  • Mybatis用注解写in查询的实现

    Mybatis用注解写in查询的实现

    这篇文章主要介绍了Mybatis用注解写in查询的实现方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-07-07
  • Java动态规划篇之线性DP的示例详解

    Java动态规划篇之线性DP的示例详解

    这篇文章主要通过几个例题为大家详细介绍一些Java动态规划中的线性DP,文中的示例代码讲解详细,对我们学习Java有一定的帮助,需要的可以参考一下
    2022-11-11
  • 关于springboot2.4跨域配置问题

    关于springboot2.4跨域配置问题

    这篇文章主要介绍了springboot2.4跨域配置的方法,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-07-07
  • IDEA工程运行时总是报xx程序包不存在实际上包已导入(问题分析及解决方案)

    IDEA工程运行时总是报xx程序包不存在实际上包已导入(问题分析及解决方案)

    这篇文章主要介绍了IDEA工程运行时,总是报xx程序包不存在,实际上包已导入,本文给大家分享问题分析及解决方案,通过实例代码给大家介绍的非常详细,需要的朋友可以参考下
    2020-08-08
  • Java处理压缩文件的步骤详解

    Java处理压缩文件的步骤详解

    在Java编程环境中,处理zip压缩文件是一项常见的任务,特别是在数据传输、备份或者打包应用程序时,本文将详细讲解Java处理压缩文件的步骤,并有相关的代码示例供大家参考,需要的朋友可以参考下
    2024-10-10
  • SpringBoot中@ConfigurationProperties自动获取配置参数的流程步骤

    SpringBoot中@ConfigurationProperties自动获取配置参数的流程步骤

    当需要获取配置文件中很多参数时,我们可以定义参数的前缀相同,通过自动映射 进行获取配置文件中参数,所以本文给大家介绍了SpringBoot中@ConfigurationProperties自动获取配置参数的流程步骤,需要的朋友可以参考下
    2024-11-11
  • SpringBoot 防止接口恶意多次请求的操作

    SpringBoot 防止接口恶意多次请求的操作

    这篇文章主要介绍了SpringBoot 防止接口恶意多次请求的操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-01-01
  • 浅析Spring的事务实现原理

    浅析Spring的事务实现原理

    这篇文章主要为大家详细介绍了Spring中事务实现的原理,文中的示例代码讲解详细,对我们学习Spring有一定的帮助,需要的可以参考一下
    2022-11-11
  • java实现上传文件类型检测过程解析

    java实现上传文件类型检测过程解析

    这篇文章主要介绍了java实现上传文件类型检测过程解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-12-12
  • SpringCloud使用Feign实现动态路由操作

    SpringCloud使用Feign实现动态路由操作

    这篇文章主要介绍了SpringCloud使用Feign实现动态路由操作,文章围绕主题展开详细的内容介绍具有一定的参考价值,需要的小伙伴可以参考一下
    2022-06-06

最新评论