当前位置:   article > 正文

Java中QueryWrapper的使用_java querywrapper

java querywrapper

Java中QueryWrapper的使用


前言

提示:在实际开发中,我们现在越来越要熟悉的使用Mybatis-plus等便捷式开发技术了。小编不才,接下来我将会将我开发中常用到的方法总结一下。


提示:以下是本篇文章正文内容,下面案例可供参考

一、QueryWrapper是什么?

说明:其实,说白了,QueryWrapper就是咱们在使用Mybatis-plus中真实用到的一种技术,也叫作构造器。

二、常用使用方法总结

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);
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9

以上代码对应的sql为:

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

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

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

函数名说明例子
eq等于例:eq(“name”,“张子”) ===> name = ‘张子’
ne不等于例:ne(“name”,“张子”) ===> name <> ‘张子’
gt大于例:gt(“age”,“18”) ===> age>18
lt小于例:lt(“age”,“18”) ===> age<18
between在值1到值2之间例:between(“age”,18,30) ===> 18<age<30’
like模糊查询例:like(“name”,“张”) ===> name like ‘%张%’
isNull字段为NULL例:isNull(“name”) ===> name is null

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);
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29

总结

以上就是今天我所讲的内容。如果你喜欢我的文章,对你还算是有所收获的话,请点赞、评论、收藏,你对我的支持将是我最大的动力!Thank You!

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/小小林熬夜学编程/article/detail/158352
推荐阅读
相关标签
  

闽ICP备14008679号