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

这篇具有很好参考价值的文章主要介绍了MyBatis-Plus——条件构造器Wapper、QUeryWrapper、UpdateWrapper、LambdaQueryWrapper、LambdaUpdateWrapper(详解)。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

目录

一、条件构造器简介

二、QueryWrapper组装查询条件

三、QueryWrapper组装排序条件

四、QueryWrapper组装删除条件

五、QueryWrapper实现修改功能

六、QueryWrapper条件的优先级

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

八、QueryWrapper组装子查询

九、UpdateWrapper实现修改功能

十、QueryWrapper使用condition组装条件

十一、LambdaQueryWrapper(推荐)

十一、LambdaUpdateWrapper(推荐)


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

一、条件构造器简介

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

二、QueryWrapper组装查询条件

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

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

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

三、QueryWrapper组装排序条件

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

四、QueryWrapper组装删除条件

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

http://t.csdn.cn/ax2cR

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

五、QueryWrapper实现修改功能

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

gt()是大于的意思

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

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

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

六、QueryWrapper条件的优先级

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

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

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

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

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

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

    八、QueryWrapper组装子查询

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

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

九、UpdateWrapper实现修改功能

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

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

十、QueryWrapper使用condition组装条件

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

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

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

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

十一、LambdaQueryWrapper(推荐)

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

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

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

三个参数,第一个参数: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(推荐)

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

十二、实际开发案例

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

MyBatis-Plus——条件构造器Wapper、QUeryWrapper、UpdateWrapper、LambdaQueryWrapper、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语句的话,如下所示文章来源地址https://www.toymoban.com/news/detail-471286.html

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

到了这里,关于MyBatis-Plus——条件构造器Wapper、QUeryWrapper、UpdateWrapper、LambdaQueryWrapper、LambdaUpdateWrapper(详解)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • MyBatis-Plus条件构造器[常用的模糊查询、排序查询、逻辑查询和指定字段查询案例]

    Mybatis-Plus知识点[MyBatis+MyBatis-Plus的基础运用]_心态还需努力呀的博客-CSDN博客  Mybatis-Plus+SpringBoot结合运用_心态还需努力呀的博客-CSDN博客 MyBaits-Plus中@TableField和@TableId用法_心态还需努力呀的博客-CSDN博客 MyBatis-Plus中的更新操作(通过id更新和条件更新)_心态还需努力呀的博客

    2024年02月06日
    浏览(78)
  • 【MyBatis Plus】深入探索 MyBatis Plus 的条件构造器,自定义 SQL语句,Service 接口的实现

    在前文中,介绍了 MyBatis Plus 的一些基础功能,我们发现使用MyBatis Plus 可以非常简单的就实现对单表的增删改查操作。但是这些操作对应的 SQL 语句都非常简单,如果是面对一些复杂的 SQL 或者多表查询这样的情况,就需要我们自己来重新组织 SQL 语句了。 本文将重点探索 M

    2024年02月07日
    浏览(41)
  • Java中使用es条件构造器BoolQueryBuilder

    由于es在java中查询没法像mybatis那样方便,而且es的构造器使用也比较繁琐,理解不是很方便,所以写一篇文章来记录es构造器BoolQueryBuilder查询时各种条件的构造的正确姿势。 1.构造准备 2.条件构造 must可用filter代替,查询效率会更高,因为must会对结果进行_score评估 3.构造完成

    2024年02月11日
    浏览(44)
  • MybatisPlus-CRUD,不带条件构造器的常用方法

    BaseMapper中封装好了增删改查的方法 后面直接调用就好了 测试类 ----------------------------------------------------------------- ServiceImpl中封装了方法(特别注意批量添加只有serviceImpl中有) 测试类

    2024年02月14日
    浏览(26)
  • MyBatisPlus详解(二)条件构造器Wrapper、自定义SQL、Service接口

    MyBatisPlus详解系列文章: MyBatisPlus详解(一)项目搭建、@TableName、@TableId、@TableField注解与常见配置 2.1.1 Wrapper 在BaseMapper接口提供的相关方法中,除了以id作为where条件, 还支持更加复杂的where条件,即条件构造器Wrapper : Wrapper是条件构造器的抽象类,其下有很多默认实现,继承

    2024年04月25日
    浏览(40)
  • Mybatisplus 传参参数为自定义sql, 使用条件构造器作为参数

    1 pom依赖 2 mapper 接口文件 3 mapper 的xml配置文件 4 查询 5 测试,生成的两个sql语句如下 注意 :不同的版本,可能会有部分区别,总之注意下版本

    2024年02月22日
    浏览(41)
  • Java中构造器详解(类的五成员之三:构造器)

    先看文章目录,大致了解知识点结构,直接点击文章目录可以跳转到文章指定位置。 Java的基本单位是类,类中包含五个部分,这篇写的是 构造器 。 (1)变量 (2)方法 (3)构造器 (4)初始化块 (5)内部类 ①构造器是处于Java类中的一个方法,最大的作用创建对象时执行

    2024年02月08日
    浏览(36)
  • 7.5 构造器详解

    7.5 构造器详解 类中的构造器也称为构造方法,是在进行创建对象的时候必须要调用的。并且构造器有以下两个特点: 必须和类的名字相同 必须没有返回类型,也不能写void 一个类即使什么都不写都会存在一个构造方法。 构造器的作用 可以实例化一些初始值,比如一些游戏

    2024年02月14日
    浏览(29)
  • Java 构造器

    2024年02月12日
    浏览(100)
  • 单例模式与构造器模式

    单例模式(Singleton Pattern):创建型模式,提供了一种创建对象的最佳方式,这种模式涉及到一个单一的类,该类负责创建自己的对象,同时确保只有单个对象被创建 在应用程序运行期间,单例模式只会在全局作用域下创建一次实例对象,让所有需要调用的地方都共享这一单

    2024年02月15日
    浏览(29)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包