当前位置:   article > 正文

LambdaQueryWrapper构建器

lambdaquerywrapper

文章介绍:主要用于条件查询时条件的构造

一、LambdaQueryWrapper是用来干嘛的?

LambdaQueryWrapper是mybatis plus中的一个条件构造器对象,只是是需要使用Lambda 语法使用 Wrapper

二、使用语法

请添加图片描述

 三、代码示例

  1. public Page<Merchants> shopList(Query info) {
  2. LambdaQueryWrapper<User> queryWrapper = new LambdaQueryWrapper<>();
  3. //单字段查询
  4. queryWrapper.eq(User::getState, 0);
  5. queryWrapper.eq(User::getSmsType, 1);
  6. //不等于
  7. queryWrapper.ne(User::getDietTypeId,0);
  8. // 模糊搜索条件
  9. if (StringUtils.notEmpty(info.getKeyword())) {
  10. queryWrapper.and(c -> c.like(User::getMallName, info.getKeyword())
  11. .or().like(User::getOwnerId, info.getKeyword())
  12. .or().like(User::getOwnerName, info.getKeyword()));
  13. }
  14. // 时间范围查询
  15. if (StringUtils.notEmpty(info.getCreateTimeStart()) && StringUtils.notEmpty(info.getCreateTimeEnd())) {
  16. queryWrapper.ge(User::getCreateTime, info.getCreateTimeStart());
  17. queryWrapper.le(User::getCreateTime, info.getCreateTimeEnd());
  18. }
  19. // 不为空
  20. queryWrapper.isNotNull(User::getStartTime);
  21. // 排序条件
  22. if (StringUtils.notEmpty(info.getSort()) && StringUtils.notEmpty(info.getOrder())) {
  23. // sort ---> "create_time" , order -> desc,asc
  24. queryWrapper.last(" order by ".concat(info.getSort()).concat(" ").concat(info.getOrder()));
  25. }
  26. // 排序(另一种写法)
  27. if (Func.isEmpty(req.getSortType()) || req.getSortType() == 0) {
  28. queryWrapper.orderByDesc(User::getTestTime);
  29. } else {
  30. queryWrapper.orderByAsc(User::getTestTime);
  31. }
  32. //limit
  33. queryWrapper.last(" limit 1");
  34. return merchantService.page(new Page<>(info.getPage(), info.getSize()), queryWrapper);
  35. }

四、list.stream.filter过滤器

1、过滤示例按条件筛选数据

  1. 在Java8中对集合的操作可以这样操作
  2. 1.查找集合中的第一个对象
  3. Optional<Object> first= ObjectList.stream() .filter(a -> "hanmeimei".equals(a.getUserName())) .findFirst();
  4. 2.返回符合查询条件的集合
  5. //所有名字叫hanmeimei的集合
  6. List<Object> firstObject= ObjectList.stream() .filter(a -> "hanmeimei".equals(a.getUserName())) .collect(Collectors.toList());
  7. //所有名字为空的集合
  8. List<Object> firstObject= ObjectList.stream() .filter(a -> StringUtils.isEmpty(a.getUserName())) .collect(Collectors.toList());

2、过滤数据大于20的数据

  1. private List<Integer> integers = Lists.list(30, 40, 10, 20);
  2. Set<Integer> collect = integers.stream()
  3. .filter(i -> i > 20).collect(Collectors.toSet());
  4. assertEquals(Sets.newTreeSet(30, 40), collect);

3、 map 对每个元素执行操作,不会改变原本数量

  1. private List<Integer> integers = Lists.list(30, 40, 10, 20);
  2. List<String> collect = integers.stream().map(i -> i + "哈哈").collect(Collectors.toList());
  3. assertEquals(Lists.list("30哈哈", "40哈哈", "10哈哈", "20哈哈"), collect);

4、mapToInt 转成IntSream类型转换

  1. ArrayList<Integer> list = Lists.list(2, 5, 1, 6);
  2. IntStream intStream = list.stream().mapToInt(i -> i);
  3. List<Integer> collect = intStream.boxed()
  4. .collect(Collectors.toList()); // boxed() 把int转成Integer??
  5. System.out.println(collect);
  6. // mapToDouble mapToLong 同理

5、flatMap 类似把多个集合压平成一个?

  1. ArrayList<ArrayList<Integer>> list = Lists.list(Lists.list(1, 2, 3), Lists.list(1, 2, 3));
  2. Stream<Integer> integerStream = list.stream().flatMap(Collection::stream);
  3. List<Integer> collect = integerStream.collect(Collectors.toList());
  4. System.out.println(collect);//[1, 2, 3, 1, 2, 3]
  5. // list.stream().flatMapToInt() TODO

6、 distinct 去重

  1. List<Integer> integers = Lists.list(30, 40, 10, 20, 20, 10, 50, 20);
  2. List<Integer> collect = integers.stream().distinct().collect(Collectors.toList());
  3. System.out.println(collect);//[30, 40, 10, 20, 50]

7、sorted 排序中间40判断可不要

  1. collect = integers.stream().sorted().collect(Collectors.toList());
  2. System.out.println(collect);// [10, 10, 20, 20, 20, 30, 40, 50]
  3. collect = integers.stream().sorted((x, y) -> {//这里认为40 不吉利 自定义排到最后
  4. if (y == 40) {
  5. return -1; // 注意 排序比较时 结果 1排在前,-1排在后
  6. }else if (x==40){
  7. return 1;
  8. }
  9. return x.compareTo(y);
  10. }).collect(Collectors.toList());
  11. System.out.println(collect);// [10, 10, 20, 20, 20, 30, 50, 40]

8、limit 限定流元素数量

  1. List<Integer> integers = Lists.list(30, 40, 10, 20, 20, 10, 50, 20);
  2. List<Integer> collect = integers.stream().limit(3).collect(Collectors.toList());
  3. System.out.println(collect); // [30, 40, 10]

9. skip 跳过多少个元素

  1. List<Integer> q = Lists.list(30, 40, 10, 20, 20, 10, 50, 20);
  2. List<Integer> collect5 = q.stream().skip(2).collect(Collectors.toList());
  3. System.out.println(collect5); // [10, 20, 20, 10, 50, 20]

10. foreach foreachOrdered 遍历

  1. Stream<Integer> limit = Stream.iterate(0,x->x+1).limit(100);
  2. List list = new ArrayList();
  3. // limit.parallel().forEachOrdered(list::add);// [0, 1, 2, 3, 4...
  4. limit.parallel().forEach(list::add);// [62, 63, 64, 65,...
  5. System.out.println(list);

11. reduce 合并?累加

a,b,c -> (a+b),c -> (a+b+c) -> result

  1. List<Integer> integers = Lists.list(30, 40, 10, 20, 20, 10, 50, 20);
  2. Integer reduce = integers.stream().reduce(0, (x, y) -> x + y);
  3. Integer integer = integers.stream().reduce((x, y) -> x + y).orElse(-1);
  4. Integer reduce1 = integers.stream().reduce(0, (x, y) -> x + y,Integer::sum);
  5. System.out.println(reduce); // 200
  6. System.out.println(integer); // 200
  7. System.out.println(reduce1); // 200

12. collect 收集

  1. List<Integer> integers = Lists.list(30, 40, 10, 20, 20, 10, 50, 20);
  2. ArrayList<Object> collect1 = integers.stream()
  3. .collect(ArrayList::new, ArrayList::add, ArrayList::add);
  4. // 在combiner使用时,你的Stream是平行的,因为在这种情况下,
  5. // 多个线程收集的元素Stream到最终输出的子列表ArrayList,
  6. // 并且这些子列表必须被组合以产生最终的ArrayList。
  7. System.out.println(collect1);// [30, 40, 10, 20, 20, 10, 50, 20]

13. min 最小 count总数

  1. List<Integer> integers = Lists.list(30, 40, 10, 20, 20, 10, 50, 20);
  2. Integer integer1 = integers.stream().min(Integer::compareTo).orElse(-1);
  3. System.out.println(integer1); //10
  4. long count = integers.stream().count();
  5. System.out.println(count);//8

14. findFirst 第一个 findAny 随便一个

  1. List<Integer> integers = Lists.list(30, 40, 10, 20, 20, 10, 50, 20);
  2. Integer integer2 = integers.stream().findFirst().orElse(-1);
  3. System.out.println(integer2);
  4. Integer integer3 = integers.stream().findAny().orElse(-1);
  5. System.out.println(integer3);//30

15. Stream.iterate Stream.generate 生成一个无限流后者可以自定义实现方法
必须有limit限制,否则无限

  1. List<Integer> collect3 = Stream.iterate(0, (x) -> ++x).limit(100).collect(Collectors.toList());
  2. System.out.println(collect3);
  3. List<Integer> collect4 = Stream.generate(MyStreamTest::get).limit(200)
  4. .collect(Collectors.toList());
  5. System.out.println(collect4);
  6. private static Integer get() {
  7. return RandomUtils.nextInt(1, 1000);
  8. }

16. Stream.concat 组合俩流

如果两个都排好序 那组合的也排好序

  1. Stream<Integer> limit = Stream.generate(MyStreamTest::get).limit(10).sorted();
  2. Stream<Integer> limit1 = Stream.generate(MyStreamTest::get).limit(10).sorted();
  3. List<Integer> collect = Stream.concat(limit, limit1).collect(Collectors.toList());
  4. System.out.println(collect);

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

闽ICP备14008679号