Mybatis-plus中QueryWrapper的使用

一、QueryWrapper是什么?

QueryWrapper就是在使用Mybatis-plus中真实用到的一种技术,也叫作构造器,能简化sql的操作。

二、常用方法总结

1、单表操作

代码如下(示例):我要查询姓名、班级、年龄符合前端传过来参数的数据并进行排序。

@GetMapping("/list")
public TableDataInfo list(Student student){
	LambdaQueryWrapper<Student> lqw = new LambdaQueryWrapper<Student>();
	lqw.eq(Student::getName, student.getName());
	lqw.like(Student::getClass,student.getClass());
	lqw.between("age",student.getAge1(),student.getAge2());
	lqw.orderByAsc("age");
	List<Student> list = studentService.list(lqw);
}

以上代码对应的sql为:

select * from student where name = '?' and class like '%?%' and age between '?' and '?' order by '?' asc

由此可以看出,QueryWrapper其实可以理解成一个放查询条件的盒子,我们把查询条件放在里面,他就会自动按照对应的条件进行查询数据。

根据不同的查询要求,有不同的用法,常用到的比如:eq、like、and、or、isNull、isNotNull、ne、likeRight、between等;使用方法及说明见下图。
在这里插入图片描述

2、多表操作

//Controller
@GetMapping("/listAndClass")
public TableDataInfo listAndClass(Student student)
{
    QueryWrapper<Student > qw = new QueryWrapper<Student >();
    if(StringUtils.isNotBlank(student.getName())){
        qw.eq("s.name",student.getName());
    }
    if(StringUtils.isNotBlank(student.getClassName())){
        qw.like("c.name",student.getClassName());
    }
    startPage();
    List<Student > list = studentService.listAndClass(qw);
    return getDataTable(list);
}

//Service
 List<Student> listAndClass(QueryWrapper<Student> qw);

//Service impl
@Override
public List<Student> listAndClass(QueryWrapper<Student> qw) {
    return this.getBaseMapper().listAndClass(qw);
}

//Mapper
@Select("select s.*,c.name from student s left join class c on s.id = c.student_id "+
        "${ew.customSqlSegment}")
List<YwSpaqjgDj> listAndClass(@Param(Constants.WRAPPER) QueryWrapper<Student> qw);

  • 10
    点赞
  • 32
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: Mybatis-Plus是一个优秀的ORM框架,它在MyBatis的基础上进行了功能扩展和优化,并且针对常见的业务场景提供了常用的解决方案。其QueryWrapperMybatis-Plus提供的查询构造器,支持多条件查询、排序、分页等功能。QueryWrapper多条件排序功能可以在查询时根据多个条件对结果进行排序。例如,我们可以通过QueryWrapper的order()方法来设置排序规则: QueryWrapper<User> queryWrapper = new QueryWrapper<>(); queryWrapper .eq("sex", 1) .ge("age", 18) .orderByAsc("age") //按照年龄升序排序 .orderByDesc("create_time"); //按照创建时间降序排序 在上述代码,我们通过eq()方法设置性别为男性,通过ge()方法设置年龄大于等于18岁,然后通过orderByAsc()方法设置按照年龄升序排序,最后通过orderByDesc()方法设置按照创建时间降序排序。这样,最终查询结果会按照这两个条件的要求进行排序。 总之,Mybatis-PlusQueryWrapper多条件排序功能可以方便地实现排序需求,提高查询效率,为开发者提供了更加便捷的操作方式。 ### 回答2: mybatis-plus是一款基于mybatis的增强工具,可以简化mybatis的开发过程。mybatis-plus提供了querywrapper多条件排序的功能,可以方便地对数据库进行多条件排序,实现数据的有序展示。 使用mybatis-plusquerywrapper进行多条件排序很简单,只需按照以下步骤进行操作: 1.创建querywrapper对象 在使用mybatis-plus查询时,需要通过querywrapper对象来添加查询条件。创建querywrapper对象非常简单,只需要调用QueryWrapper的静态方法就可以了: QueryWrapper<Entity> wrapper = new QueryWrapper<>(); 2.添加查询条件 除了添加查询条件之外,querywrapper还可以添加排序方式。多条件排序可以在wrapper对象添加多个排序规则,每个排序规则可以指定一个字段和一个排序方向。例如,以下代码添加了两个排序规则,分别按照age和name字段进行升序排序: wrapper.orderByAsc("age", "name"); 3.执行查询操作 最后使用mybatis-plus提供的基本查询方法执行查询操作,例如selectList(),selectOne(),selectPage()等方法。 总之,mybatis-plus自带querywrapper多条件排序的功能可以大大简化复杂的多条件查询操作,提高了开发效率,也方便了数据的有序展示。在实际应用,开发人员可以根据自己的需要灵活地使用这个功能。 ### 回答3: MyBatis-Plus是MyBatis的一个增强工具包,它提供了许多实用的功能,使得MyBatis编写SQL语句更加简单方便。其QueryWrapperMyBatis-Plus提供的一个查询条件构建器,它可以方便地构建各种复杂的查询条件。 QueryWrapper提供了多种方法来构建查询条件,其包括eq、ne、gt、lt、ge、le等基本的比较操作,也包括like、in、between等高级操作。同时,QueryWrapper还支持链式调用,可以方便地组合多个查询条件。 在多条件排序方面,QueryWrapper也提供了多种方法。其,orderByAsc和orderByDesc方法可以分别按照升序和降序进行排序,而orderBy方法则可以按照自定义的排序规则进行排序。同时,orderBy方法还支持链式调用,可以方便地组合多个排序规则。 除了QueryWrapperMyBatis-Plus还提供了LambdaQueryWrapper,它可以使用Lambda表达式来构建查询条件,使得代码更加简洁易懂。LambdaQueryWrapper也支持多条件排序,使用方式与QueryWrapper类似。 总之,MyBatis-Plus提供了方便、实用的QueryWrapper查询条件构建器,提供了多种方法来构建查询条件和排序规则,使得MyBatis编写SQL语句更加简单高效。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值