Java 实现分页的几种方式详解
目录
- 分页概述
- Java实现分页的几种方式
- 手动分页
- 基于JDBC的分页
- 基于Hibernate的分页
- 基于MyBatis的分页
- [基于Spring Data JPA的分页](#基于Spring Data JPA的分页)
- 使用PageHelper插件的分页
- 分页中的注意事项
- 总结
分页概述
分页是指将大量数据分成若干小块,每次只显示其中一部分,以减少系统负载并提升用户体验。实现分页的关键在于控制每页显示的数据量,以及用户请求的当前页数。
Java实现分页的几种方式
手动分页
手动分页是最基本的分页方式,通过Java代码手动控制数据的分页。以下是一个简单的例子:
import java.util.ArrayList;
import java.util.List;public class ManualPagination {public static void main(String[] args) {List<Integer> data = new ArrayList<>();for (int i = 1; i <= 100; i++) {data.add(i);}int pageSize = 10;int currentPage = 3;List<Integer> pagedData = paginate(data, pageSize, currentPage);System.out.println(pagedData);}public static <T> List<T> paginate(List<T> data, int pageSize, int currentPage) {int startIndex = (currentPage - 1) * pageSize;int endIndex = Math.min(startIndex + pageSize, data.size());if (startIndex > endIndex) {return new ArrayList<>();}return data.subList(startIndex, endIndex);}
}
这种方式适用于数据量较小的情况,对于大数据集,效率较低。
基于JDBC的分页
在JDBC中实现分页,主要通过SQL语句来控制数据的分页。以下是一个基于MySQL的例子:
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.util.ArrayList;
import java.util.List;public class JdbcPagination {private static final String URL = "jdbc:mysql://localhost:3306/your_database";private static final String USER = "root";private static final String PASSWORD = "password";public static void main(String[] args) {int pageSize = 10;int currentPage = 3;List<String> data = paginate(pageSize, currentPage);data.forEach(System.out::println);}public static List<String> paginate(int pageSize, int currentPage) {List<String> data = new ArrayList<>();String sql = "SELECT * FROM your_table LIMIT ?, ?";try (Connection conn = DriverManager.getConnection(URL, USER, PASSWORD);PreparedStatement ps = conn.prepareStatement(sql)) {ps.setInt(1, (currentPage - 1) * pageSize);ps.setInt(2, pageSize);try (ResultSet rs = ps.executeQuery()) {while (rs.next()) {data.add(rs.getString("your_column"));}}} catch (Exception e) {e.printStackTrace();}return data;}
}
这种方式适用于需要直接操作数据库的情况,效率较高。
基于Hibernate的分页
Hibernate是一个常用的ORM框架,通过它可以方便地实现分页。以下是一个例子:
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.cfg.Configuration;import java.util.List;public class HibernatePagination {public static void main(String[] args) {Configuration cfg = new Configuration().configure();SessionFactory sessionFactory = cfg.buildSessionFactory();Session session = sessionFactory.openSession();int pageSize = 10;int currentPage = 3;List<?> data = session.createQuery("FROM YourEntity").setFirstResult((currentPage - 1) * pageSize).setMaxResults(pageSize).list();data.forEach(System.out::println);session.close();sessionFactory.close();}
}
这种方式适用于使用Hibernate进行数据持久化的项目,能够很好地与其他Hibernate功能集成。
基于MyBatis的分页
MyBatis是另一个流行的ORM框架,它通过Mapper接口和XML配置文件实现数据库操作。以下是一个基于MyBatis的分页例子:
<!-- MyBatis Mapper XML Configuration -->
<select id="selectPage" parameterType="map" resultType="YourEntity">SELECT * FROM your_tableLIMIT #{offset}, #{pageSize}
</select>
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;import java.io.Reader;
import java.util.HashMap;
import java.util.List;
import java.util.Map;public class MyBatisPagination {public static void main(String[] args) {Reader reader = Resources.getResourceAsReader("mybatis-config.xml");SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(reader);SqlSession session = sqlSessionFactory.openSession();int pageSize = 10;int currentPage = 3;Map<String, Object> params = new HashMap<>();params.put("offset", (currentPage - 1) * pageSize);params.put("pageSize", pageSize);List<YourEntity> data = session.selectList("selectPage", params);data.forEach(System.out::println);session.close();}
}
MyBatis提供了灵活的SQL配置方式,适用于复杂查询需求。
基于Spring Data JPA的分页
Spring Data JPA是Spring框架中的一个模块,通过它可以方便地实现分页功能。以下是一个例子:
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.domain.Page;
import org.springframework.data.domain.PageRequest;
import org.springframework.data.domain.Pageable;
import org.springframework.stereotype.Service;@Service
public class YourService {@Autowiredprivate YourRepository repository;public void paginate(int pageSize, int currentPage) {Pageable pageable = PageRequest.of(currentPage - 1, pageSize);Page<YourEntity> page = repository.findAll(pageable);page.getContent().forEach(System.out::println);}
}
import org.springframework.data.jpa.repository.JpaRepository;public interface YourRepository extends JpaRepository<YourEntity, Long> {
}
Spring Data JPA简化了分页查询的实现,适用于使用Spring框架进行开发的项目。
使用PageHelper插件的分页
PageHelper是一个MyBatis分页插件,可以通过简单的配置实现分页功能。以下是一个例子:
import com.github.pagehelper.PageHelper;
import com.github.pagehelper.PageInfo;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;import java.io.Reader;
import java.util.List;public class PageHelperPagination {public static void main(String[] args) {Reader reader = Resources.getResourceAsReader("mybatis-config.xml");SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(reader);SqlSession session = sqlSessionFactory.openSession();int pageSize = 10;int currentPage = 3;PageHelper.startPage(currentPage, pageSize);List<YourEntity> data = session.selectList("selectPage");PageInfo<YourEntity> pageInfo = new PageInfo<>(data);pageInfo.getList().forEach(System.out::println);session.close();}
}
PageHelper插件简化了分页实现,适用于使用MyBatis的项目。
分页中的注意事项
- 性能优化:分页查询可能会对数据库性能产生影响,特别是当数据量很大时。可以通过优化索引、减少不必要的查询字段等方式提升性能。
- 用户体验:分页不仅要考虑技术实现,还要考虑用户体验。可以在前端实现无缝滚动加载、分页导航等功能,提升用户交互体验。
- 数据一致性:分页查询时要注意数据的一致性,特别是在高并发环境下,可能需要考虑数据的版本控制和乐观锁机制。
- 安全性:避免通过URL参数直接传递分页参数,防止恶意用户构造大页数或小页数的请求,导致系统负载增加。
总结
分页是Web开发中的一项基础功能,本文介绍了Java实现分页的几种常见方式,包括手动分页、基于JDBC的分页、基于Hibernate的分页
、基于MyBatis的分页、基于Spring Data JPA的分页和使用PageHelper插件的分页。每种方式都有其适用场景和优势,开发者可以根据具体需求选择合适的分页方案。
希望这篇关于Java实现分页的技术博客能够帮助你更好地理解和掌握分页技术。如果你有其他关于Java开发的疑问,欢迎随时联系我。
相关文章:
Java 实现分页的几种方式详解
目录 分页概述Java实现分页的几种方式 手动分页基于JDBC的分页基于Hibernate的分页基于MyBatis的分页[基于Spring Data JPA的分页](#基于Spring Data JPA的分页)使用PageHelper插件的分页 分页中的注意事项总结 分页概述 分页是指将大量数据分成若干小块,每次只显…...
vite构建vue3项目hmr生效问题踩坑记录
vite构建vue3项目hmr生效问题踩坑记录 hmr的好处 以下是以表格形式呈现的前端开发中HMR(热模块替换)带来的好处: 好处描述提升开发效率允许开发者在不刷新整个页面的情况下实时更新修改的代码,减少等待时间保持应用状态在模块替…...
区块链赋能民生大数据
区块链技术作为一种新兴的信息技术,其在民生大数据领域的应用正逐渐展现出巨大的潜力和价值。以下是对区块链赋能民生大数据的详细阐述: 一、区块链技术概述 区块链是一种去中心化、分布式账本技术,具有数据不可篡改、可追溯、公开透明等特…...
10 Vue 特性要点
Vue2 特性要点 Vue2 源码理解 Vue 双向数据绑定 先从单向绑定切入单向绑定非常简单,就是把Mode1绑定到view,当我们用Javascript代码更新Model时, view就会自动更新 双向绑定就很容易联想到了,在单向绑定的基础上,用户更新了View, Mode1的数据也自动被更新了 因为 Vue 是数据双向…...
ESP32和mDNS学习
目录 mDNS的作用mDNS涉及到的标准文件组播地址IPv4 多播地址IPv6 多播地址预先定义好的组播地址 mDNS调试工具例程mDNS如何开发和使用注册服务查询服务 mDNS的作用 mDNS 是一种组播 UDP 服务,用来提供本地网络服务和主机发现。 你要和设备通信,需要记住…...
学习SQL如何使用CASE语句查询分析设备状态
学习SQL如何使用CASE语句查询分析设备状态 一、前言1. 问题背景2. SQL查询分析3. SQL查询解析 二、结论 一、前言 在实际应用中,经常需要对设备的状态进行监控和分析。通过SQL查询,我们可以有效地从数据库中提取和计算设备的状态信息。本文将介绍如何编…...
Gartner发布2024年零信任网络技术成熟度曲线:20项零信任相关的前沿和趋势性技术
大多数组织都制定了零信任信息安全策略,而网络是零信任实施领域的顶级技术。此技术成熟度曲线可以帮助安全和风险管理领导者确定合适的技术,以将零信任原则嵌入其网络中。 战略规划假设 到 2026 年,15% 的企业将在企业拥有的局域网上用 ZTNA …...
React hook 之 useState
在组件的顶部定义状态变量,并传入初始值,确保当这些状态变量的值发生变化时,页面会重新渲染。 const [something,setSomething] useState(initialState); useState 返回一个由两个值组成的数组:1、当前的 state,在首次…...
jenkins中shell脚本中使用构建参数化Groovy变量的四种方式
jenkins中shell脚本中使用构建参数化Groovy变量的四种方式: 以字符变量为例: 流水线代码: pipeline {agent {//label "${server}"label "${28}"}stages {stage(Hello) {steps {echo Hello Worldecho "${28}"echo "…...
Robot Operating System——ParameterEventHandler监控Parameters的增删改行为
大纲 创建订阅"/parameter_events"的Node监控自身Node内部Parameter监控自身Node外部Parameter监听所有Node的所有Parameter的变动执行效果总结 在《Robot Operating System——AsyncParametersClient监控Parameters的增删改行为》一文中,我们通过AsyncPa…...
计算机网络(Wrong Question)
一、计算机网络体系结构 1.1 计算机网络概述 D 注:计算机的三大主要功能是数据通信、资源共享、分布式处理。(负载均衡、提高可靠性) 注:几段链路就是几段流水。 C 注:记住一个基本计算公式:若n个分组&a…...
Docker+consul容器服务的更新与发现
1、Consul概述 (1)什么是服务注册与发现 服务注册与发现是微服务架构中不可或缺的重要组件。起初服务都是单节点的,不保障高可用性,也不考虑服务的压力承载,服务之间调用单纯的通过接口访问。直到后来出现了多个节点…...
全网最详细!! Linux 安装、配置教程
一、下载安装包 首先去官网下载VMware最新版本,以及发行版CentOS -7,懒得下载的可以私信我,我给你发包 其中,CentOS(Community Enterprise Operating System)是一个基于Linux的开源操作系统,它是…...
cocos creator 3学习记录01——如何替换图片
一、动态加载本地图片 1、通过将图片关联到CCClass属性上来进行代码切换。 1、这种方法,需要提前在脚本文件中声明好代表图片的CCClass属性。 2、然后拖动图片资源,到脚本内声明好的属性上以进行关联。 3、然后通过程序,来进行切换展示。…...
【Android Compose】ListView效果
【Android Compose】ListView效果 1、Column、Row 和 Box2、LazyColumn和LazyRow3、Compose 中的状态4、ListView效果5、android-compose-codelabs Jetpack Compose 使用入门 Jetpack Compose 教程 Jetpack Compose 1、Column、Row 和 Box Compose 中的三个基本标准布局元素是 …...
【Pytorch实战教程】Pytorch中.detach()的详细介绍
detach() 是 PyTorch 中用于分离张量的计算图的一个方法。它在处理计算图时非常有用,尤其是在需要停止梯度传播的情况下。以下是 detach() 方法的详细介绍: 方法概述 detach() 方法返回一个新的张量,从当前计算图中分离出来,即返回的张量不会参与梯度计算。这在某些情况下…...
AR 眼镜之-充电动画定制-实现方案
目录 📂 前言 AR 眼镜系统版本 充电动画 1. 🔱 技术方案 1.1 方案介绍 1.2 实现方案 关机充电动画 亮屏/锁屏充电动画 2. 💠 关机充电动画 2.1 关机充电动画核心处理类与路径 2.2 实现细节 步骤一:1)定制 …...
AJAX-XMLHttpRequest 详解
(创作不易,感谢有你,你的支持,就是我前行的最大动力,如果看完对你有帮助,请留下您的足迹) 目录 前言 XMLHttpRequest 概述 主要用途 工作流程 示例代码 GET 请求示例 POST 请求示例 注意事项 工作…...
内容管理系统 Contentful 与 Baklib
对于希望管理其产品和服务的在线文档或知识库以支持其客户和员工的组织来说,市场上有太多的平台和工具。 遵循的做法之一是使用无头内容管理系统 (CMS)。 如果您是这样的组织之一,正在考虑使用无头 CMS - Contentful 之一来管理您的在线知识库࿰…...
[Mysql-视图和存储过程]
视图 视图是从一个或者几个基本表(或视图)导出的表。它与基 本表不同,是一个虚表。 创建使用视图 # 视图 -- 视图只能用来查询,不能做增删改 -- 创建视图 -- create view 视图名【view_xxx / v_xxx】 -- as 查询语句 create view…...
反向工程与模型迁移:打造未来商品详情API的可持续创新体系
在电商行业蓬勃发展的当下,商品详情API作为连接电商平台与开发者、商家及用户的关键纽带,其重要性日益凸显。传统商品详情API主要聚焦于商品基本信息(如名称、价格、库存等)的获取与展示,已难以满足市场对个性化、智能…...
大型活动交通拥堵治理的视觉算法应用
大型活动下智慧交通的视觉分析应用 一、背景与挑战 大型活动(如演唱会、马拉松赛事、高考中考等)期间,城市交通面临瞬时人流车流激增、传统摄像头模糊、交通拥堵识别滞后等问题。以演唱会为例,暖城商圈曾因观众集中离场导致周边…...
vscode(仍待补充)
写于2025 6.9 主包将加入vscode这个更权威的圈子 vscode的基本使用 侧边栏 vscode还能连接ssh? debug时使用的launch文件 1.task.json {"tasks": [{"type": "cppbuild","label": "C/C: gcc.exe 生成活动文件"…...
JVM垃圾回收机制全解析
Java虚拟机(JVM)中的垃圾收集器(Garbage Collector,简称GC)是用于自动管理内存的机制。它负责识别和清除不再被程序使用的对象,从而释放内存空间,避免内存泄漏和内存溢出等问题。垃圾收集器在Ja…...
MMaDA: Multimodal Large Diffusion Language Models
CODE : https://github.com/Gen-Verse/MMaDA Abstract 我们介绍了一种新型的多模态扩散基础模型MMaDA,它被设计用于在文本推理、多模态理解和文本到图像生成等不同领域实现卓越的性能。该方法的特点是三个关键创新:(i) MMaDA采用统一的扩散架构…...
聊一聊接口测试的意义有哪些?
目录 一、隔离性 & 早期测试 二、保障系统集成质量 三、验证业务逻辑的核心层 四、提升测试效率与覆盖度 五、系统稳定性的守护者 六、驱动团队协作与契约管理 七、性能与扩展性的前置评估 八、持续交付的核心支撑 接口测试的意义可以从四个维度展开,首…...
iOS性能调优实战:借助克魔(KeyMob)与常用工具深度洞察App瓶颈
在日常iOS开发过程中,性能问题往往是最令人头疼的一类Bug。尤其是在App上线前的压测阶段或是处理用户反馈的高发期,开发者往往需要面对卡顿、崩溃、能耗异常、日志混乱等一系列问题。这些问题表面上看似偶发,但背后往往隐藏着系统资源调度不当…...
QT3D学习笔记——圆台、圆锥
类名作用Qt3DWindow3D渲染窗口容器QEntity场景中的实体(对象或容器)QCamera控制观察视角QPointLight点光源QConeMesh圆锥几何网格QTransform控制实体的位置/旋转/缩放QPhongMaterialPhong光照材质(定义颜色、反光等)QFirstPersonC…...
免费数学几何作图web平台
光锐软件免费数学工具,maths,数学制图,数学作图,几何作图,几何,AR开发,AR教育,增强现实,软件公司,XR,MR,VR,虚拟仿真,虚拟现实,混合现实,教育科技产品,职业模拟培训,高保真VR场景,结构互动课件,元宇宙http://xaglare.c…...
NPOI操作EXCEL文件 ——CAD C# 二次开发
缺点:dll.版本容易加载错误。CAD加载插件时,没有加载所有类库。插件运行过程中用到某个类库,会从CAD的安装目录找,找不到就报错了。 【方案2】让CAD在加载过程中把类库加载到内存 【方案3】是发现缺少了哪个库,就用插件程序加载进…...
