Java基础——IService.class 中查询数据方法list() 源码剖析及使用

下面详细介绍Mybatis-plus 的默认服务IService.class 中的查询数据的方法及使用。

方法定义及其详细介绍

  1. default List<T> list(Wrapper<T> queryWrapper)

    java 复制代码
    default List<T> list(Wrapper<T> queryWrapper) {
        return this.getBaseMapper().selectList(queryWrapper);
    }
    • 功能 :根据传入的 queryWrapper 查询符合条件的所有记录。

    • 参数

      • queryWrapperWrapper<T> 实例,用于定义查询条件。这可以是 QueryWrapper<T>LambdaQueryWrapper<T>,允许你以链式调用的方式构建查询条件。
    • 返回值:符合查询条件的记录列表。

    • 使用方法

      java 复制代码
      QueryWrapper<TOreq> queryWrapper = new QueryWrapper<>();
      queryWrapper.eq("status", "active");
      List<TOreq> activeRecords = service.list(queryWrapper);
  2. default List<T> list(IPage<T> page, Wrapper<T> queryWrapper)

    java 复制代码
    default List<T> list(IPage<T> page, Wrapper<T> queryWrapper) {
        return this.getBaseMapper().selectList(page, queryWrapper);
    }
    • 功能:分页查询符合条件的记录,返回当前页的数据列表。

    • 参数

      • pageIPage<T> 实例,用于指定分页信息,如当前页码和每页记录数。通常使用 Page<T> 类的实现。
      • queryWrapperWrapper<T> 实例,用于定义查询条件。
    • 返回值:当前页符合条件的记录列表。

    • 使用方法

      java 复制代码
      IPage<TOreq> page = new Page<>(1, 10); // 第1页,每页10条记录
      QueryWrapper<TOreq> queryWrapper = new QueryWrapper<>();
      queryWrapper.eq("status", "active");
      IPage<TOreq> resultPage = service.list(page, queryWrapper);
      List<TOreq> activeRecords = resultPage.getRecords();
  3. default List<T> list()

    java 复制代码
    default List<T> list() {
        return this.list((Wrapper)Wrappers.emptyWrapper());
    }
    • 功能:查询所有记录,不使用任何查询条件。

    • 参数:无。

    • 实现 :调用 list(Wrapper<T> queryWrapper) 方法,并传递一个空的 Wrapper 实例。Wrappers.emptyWrapper() 返回一个空的 Wrapper 实例,表示没有任何查询条件。

    • 返回值:所有记录的列表。

    • 使用方法

      java 复制代码
      List<TOreq> allRecords = service.list();
  4. default List<T> list(IPage<T> page)

    java 复制代码
    default List<T> list(IPage<T> page) {
        return this.list(page, Wrappers.emptyWrapper());
    }
    • 功能:分页查询所有记录,不使用任何查询条件。

    • 参数

      • pageIPage<T> 实例,用于指定分页信息。
    • 实现 :调用 list(IPage<T> page, Wrapper<T> queryWrapper) 方法,并传递一个空的 Wrapper 实例。Wrappers.emptyWrapper() 返回一个空的 Wrapper 实例,表示没有任何查询条件。

    • 返回值:当前页的数据列表,包括所有记录。

    • 使用方法

      java 复制代码
      IPage<TOreq> page = new Page<>(1, 10); // 第1页,每页10条记录
      List<TOreq> allRecords = service.list(page);

区别及使用方法总结

  1. 查询条件

    • list(Wrapper<T> queryWrapper)list(IPage<T> page, Wrapper<T> queryWrapper):允许使用自定义的查询条件。
    • list()list(IPage<T> page):不使用查询条件,分别是查询所有记录和分页查询所有记录。
  2. 分页

    • list(IPage<T> page, Wrapper<T> queryWrapper)list(IPage<T> page):支持分页查询,需要提供 IPage<T> 实例。
    • list(Wrapper<T> queryWrapper)list():不支持分页查询,返回所有符合条件的记录。
  3. 默认实现

    • list()list(IPage<T> page) 方法使用 Wrappers.emptyWrapper() 作为查询条件,默认情况下查询所有记录或进行分页查询所有记录。
    • list(Wrapper<T> queryWrapper)list(IPage<T> page, Wrapper<T> queryWrapper) 方法允许传递具体的查询条件或分页信息,提供更灵活的查询方式。

使用示例

  • 查询所有记录

    java 复制代码
    List<TOreq> allRecords = service.list();
  • 分页查询所有记录

    java 复制代码
    IPage<TOreq> page = new Page<>(1, 10); // 第1页,每页10条记录
    List<TOreq> pagedRecords = service.list(page);
  • 使用条件查询所有记录

    java 复制代码
    QueryWrapper<TOreq> queryWrapper = new QueryWrapper<>();
    queryWrapper.eq("status", "active");
    List<TOreq> activeRecords = service.list(queryWrapper);
  • 分页条件查询

    java 复制代码
    IPage<TOreq> page = new Page<>(1, 10); // 第1页,每页10条记录
    QueryWrapper<TOreq> queryWrapper = new QueryWrapper<>();
    queryWrapper.eq("status", "active");
    IPage<TOreq> resultPage = service.list(page, queryWrapper);
    List<TOreq> activeRecords = resultPage.getRecords();

这些方法提供了不同的查询方式,允许你灵活地获取所需的数据。根据实际需求选择合适的方法进行数据查询。

相关推荐
天天摸鱼的java工程师3 分钟前
深入理解 Spring 核心:IOC 与 AOP 的原理与实践
java·后端
漫步者TZ4 分钟前
【Netty系列】解决TCP粘包和拆包:LengthFieldBasedFrameDecoder
java·网络协议·tcp/ip·netty
QQ676580088 分钟前
基于 PyTorch 的 VGG16 深度学习人脸识别检测系统的实现+ui界面
人工智能·pytorch·python·深度学习·ui·人脸识别
木木黄木木9 分钟前
Python制作史莱姆桌面宠物!可爱的
开发语言·python·宠物
愿你是阳光060729 分钟前
Java-redis实现限时在线秒杀功能
java·redis·bootstrap
胖哥真不错37 分钟前
Python基于方差-协方差方法实现投资组合风险管理的VaR与ES模型项目实战
python·毕业设计·课程设计·方差-协方差方法·投资组合风险管理·var与es模型
我爱Jack37 分钟前
Spring Boot统一功能处理深度解析
java·spring boot·后端
慧一居士41 分钟前
flask功能使用总结和完整示例
python
苦学编程的谢1 小时前
Java网络编程API 1
java·开发语言·网络
大模型铲屎官1 小时前
【深度学习-Day 23】框架实战:模型训练与评估核心环节详解 (MNIST实战)
人工智能·pytorch·python·深度学习·大模型·llm·mnist