MyBatis-Plus——条件构造器Wapper、QUeryWrapper、UpdateWrapper、LambdaQueryWrapper、LambdaUpdateWrapper(详解)

2023-05-16

目录

一、条件构造器简介

二、QueryWrapper组装查询条件

三、QueryWrapper组装排序条件

四、QueryWrapper组装删除条件

五、QueryWrapper实现修改功能

六、QueryWrapper条件的优先级

七、QueryWrapper组装select字句(查询指定字段)

八、QueryWrapper组装子查询

九、UpdateWrapper实现修改功能

十、QueryWrapper使用condition组装条件

十一、LambdaQueryWrapper(推荐)

十一、LambdaUpdateWrapper(推荐)


一、条件构造器简介

二、QueryWrapper组装查询条件

如果下面这个selectList的参数是null的话,就是查询全部

下面这个queryWrapper可以一直增加条件,并不是一个条件

三、QueryWrapper组装排序条件

四、QueryWrapper组装删除条件

如果是添加了逻辑删除的话,数据并不会从数据库中消息,具体可查看下面的链接文章中的@TableLogic注解

http://t.csdn.cn/ax2cR

五、QueryWrapper实现修改功能

如果条件是并且的话,我们不用管直接.就可以,但是如果是或者的话,记得加or()

gt()是大于的意思

第一个参数是修改的内容,第二个参数是修改的条件

运行结果就是:符合条件的姓名被改成小明,邮箱被修改成test@atguigu.com

六、QueryWrapper条件的优先级

lambda表达式中的条件优先执行

七、QueryWrapper组装select字句(查询指定字段,查询投影)

推荐下面这种形式,很推荐,省的字段名写错

    八、QueryWrapper组装子查询

在此次子查询中,“uid”是一个字段,后面的那个参数就是子查询,让uid在子查询的范围内,所以用了inSql方法

九、UpdateWrapper实现修改功能

和  QueryWrapper对比:没有创建实体类对象,所以是null

十、QueryWrapper使用condition组装条件

condition这个参数就是判断我们传入的参数是否满足condition的条件,

 经过我们的观察也可以得知,只有username和ageEnd符合condition的条件,所以我们查询的时候只查询符合condition条件的,另一个不满足条件的我们就不查询了

十一、LambdaQueryWrapper(推荐)

想访问哪一个字段,就访问实体类中对应的属性即可(避免了我们写错字段名

 也可以我们下面这种写法,都可以

三个参数,第一个参数:condition参数,判断是否满足条件,如果满足条件就查询,反之不查询

                    第二个参数:实体类中的属性对应数据库中的字段名

                    第三个参数:值

       LambdaQueryWrapper<Book> lqw = new  LambdaQueryWrapper<Book>();
        System.out.println(book);
        lqw.like(Strings.isNotEmpty(book.getType())    , Book::getType       , book.getType());
        lqw.like(Strings.isNotEmpty(book.getBookName()) , Book::getBookName , book.getBookName());
        lqw.like(Strings.isNotEmpty(book.getStatue())   , Book::getStatue   , book.getStatue());

十一、LambdaUpdateWrapper(推荐)

十二、实际开发案例

    如下图所示,要根据方法名称、方法路径完成分页模糊查询的功能

我感觉下面主要的就是使用了一个and语法

    public IPage<SysMethodQueryPageOutputDto> getQueryPageSysMethod(SysMethodInputDtO inputDto) {
//      SysMethod分页查询数据库
        IPage<SysMethod> page = new Page<>(inputDto.getCurrentPage(), inputDto.getPageSize());
        LambdaQueryWrapper<SysMethod> lqw = new LambdaQueryWrapper<>();
        lqw.eq(!Objects.isNull(inputDto.getType()) && !inputDto.getNameOrPath().equals("") , SysMethod::getType, inputDto.getType())
                .eq(!Objects.isNull(inputDto.getState())  && !inputDto.getNameOrPath().equals(""), SysMethod::getState, inputDto.getState());
        if (inputDto.getNameOrPath()  !=null  && !inputDto.getNameOrPath().equals("")){
            //两个字段用同一个值进行查询
            lqw.and(i -> i.like(!Strings.isEmpty( inputDto.getNameOrPath()), SysMethod::getMethodName, inputDto.getNameOrPath())
                    .or()
                    .like(!Strings.isEmpty(inputDto.getNameOrPath()), SysMethod::getMethodPath, inputDto.getNameOrPath()));
        }
        IPage<SysMethod> sysMethodIPage = sysMethodService.selectPage(page, lqw);


}

 如果直接使用sql语句的话,如下所示

select * FROM  sys_method
WHERE CONCAT(method_name) like '%s%' 
		 OR
			CONCAT(method_path) like '%s%'
			
SHOW CREATE TABLE sys_method

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

MyBatis-Plus——条件构造器Wapper、QUeryWrapper、UpdateWrapper、LambdaQueryWrapper、LambdaUpdateWrapper(详解) 的相关文章

  • TCP三次握手四次挥手(图解)

    TCP三次握手 TCP连接的建立是一个三次握手的过程 如图所示 xff1a 主机A xff08 通常也称为客户端 xff09 发送一个标识了SYN的数据段 xff0c 表示期望与服务器A建立连接 xff0c 此数据段的序列号 xff08 s

随机推荐