JSP+Servlet实现列表分页功能
分享一种最简单的JSP+Servlet实现分页的方式!
旧:无分页功能的查询列表功能,仅供参考!
Servlet
try {Connection conn = null;PreparedStatement ps = null;ResultSet rs = null;List<Dept> arrayList = null;conn = DBUtil.getConncetion();ps = conn.prepareStatement("select DEPTNO,DNAME,LOC from dept");rs = ps.executeQuery();//遍历结果集while (rs.next()) {String DEPTNO = rs.getString("DEPTNO");String DNAME = rs.getString("DNAME");String LOC = rs.getString("LOC");//将以上零散的数据封装成java对象Dept dept = new Dept();dept.setDEPTNO(DEPTNO);dept.setDNAME(DNAME);dept.setLOC(LOC);//将部门对象放在集合中arrayList.add(dept);}//将集合放在请求域中request.setAttribute("deptList", arrayList);//转发request.getRequestDispatcher("/list.jsp").forward(request, response);} catch (Exception e) {e.printStackTrace();response.sendError(HttpServletResponse.SC_INTERNAL_SERVER_ERROR, "数据库查询失败");}
JSP页面
<table border="1px" align="center" width="50%"><tr><th>序号</th><th>部门编号</th><th>部门名称</th><th>操作</th></tr><c:forEach items="${deptList}" var="dept" varStatus="deptus"><tr><%--deptus属性里有个count用以计数--%><th>${deptus.count}</th><th>${dept.DEPTNO}</th><th>${dept.DNAME}</th><th><a href="javascript:void(0)" onclick="del(${dept.DEPTNO})" class="a-upload"style="font-size: 10px">删除</a><%--f仅起到标记的作用--%><a href="${pageContext.request.contextPath}/dept/detail?f=edit&DEPTNO=${dept.DEPTNO}"class="a-upload" style="font-size: 10px">修改</a><a href="${pageContext.request.contextPath}/dept/detail?f=detail&DEPTNO=${dept.DEPTNO}"class="a-upload" style="font-size: 10px">详情</a></th></tr></c:forEach>
</table>
新:有分页功能的查询列表功能
Servlet
int page = 1; // 默认第一页int pageSize = 5; // 每页显示 5 条记录if (request.getParameter("page") != null) {page = Integer.parseInt(request.getParameter("page"));}try {DeptDao deptDao = new DeptDao();//实际sql:select * from dept limit ? offset ?List<Dept> deptList = deptDao.page(page, pageSize);//实际sql: select count(*) from deptint total = deptDao.getTotal();int totalPages = (int) Math.ceil((double) total / pageSize);//将集合放在请求域中request.setAttribute("deptList", deptList);request.setAttribute("currentPage", page);request.setAttribute("totalPages", totalPages);//转发request.getRequestDispatcher("/list.jsp").forward(request, response);} catch (Exception e) {e.printStackTrace();response.sendError(HttpServletResponse.SC_INTERNAL_SERVER_ERROR, "数据库查询失败");}}
List<Dept> deptList = deptDao.page(page, pageSize);
public List<Dept> page(int page, int pageSize) {Connection conn = null;PreparedStatement ps = null;ResultSet rs = null;List<Dept> deptList = new ArrayList<>();try {conn = DBUtil.getConncetion();ps = conn.prepareStatement("select * from dept limit ? offset ?");ps.setInt(1, pageSize);ps.setInt(2, (page - 1) * pageSize);rs = ps.executeQuery();while (rs.next()) {Dept dept = new Dept();dept.setDEPTNO(rs.getString("DEPTNO"));dept.setLOC(rs.getString("LOC"));dept.setPEOPLE(rs.getString("PEOPLE"));dept.setDNAME(rs.getString("DNAME"));deptList.add(dept);}} catch (Exception e) {e.printStackTrace();} finally {DBUtil.close(conn, ps, rs);}return deptList;}
int total = deptDao.getTotal();
public int getTotal() {Connection conn = null;PreparedStatement ps = null;ResultSet rs = null;try {conn = DBUtil.getConncetion();ps = conn.prepareStatement("select count(*) from dept");rs = ps.executeQuery();if (rs.next()) {return rs.getInt(1);}} catch (SQLException e) {e.printStackTrace();} finally {DBUtil.close(conn, ps, rs);}return 0;}
JSP页面
<%--分页的样式,选加!--%>
<style>.pagination {text-align: center;margin-top: 20px;}.pagination a {margin: 0 5px;text-decoration: none;color: blue;}.pagination a.disabled {color: gray;pointer-events: none;}
</style>
<table border="1px" align="center" width="50%"><tr><th>序号</th><th>部门编号</th><th>部门名称</th><th>操作</th></tr><c:forEach items="${deptList}" var="dept" varStatus="deptus"><tr><%--deptus属性里有个count用以计数--%><th>${deptus.count}</th><th>${dept.DEPTNO}</th><th>${dept.DNAME}</th><th><a href="javascript:void(0)" onclick="del(${dept.DEPTNO})" class="a-upload"style="font-size: 10px">删除</a><%--f仅起到标记的作用--%><a href="${pageContext.request.contextPath}/dept/detail?f=edit&DEPTNO=${dept.DEPTNO}"class="a-upload" style="font-size: 10px">修改</a><a href="${pageContext.request.contextPath}/dept/detail?f=detail&DEPTNO=${dept.DEPTNO}"class="a-upload" style="font-size: 10px">详情</a></th></tr></c:forEach>
</table>
<!-- 分页 -->
<div class="pagination"><%int currentPage = (int) request.getAttribute("currentPage");int totalPages = (int) request.getAttribute("totalPages");if (currentPage > 1) {%><a href="${pageContext.request.contextPath}/dept/list?page=<%= currentPage - 1 %>">上一页</a><%} else {%><a class="disabled">上一页</a><%}if (currentPage < totalPages) {%><a href="${pageContext.request.contextPath}/dept/list?page=<%= currentPage + 1 %>">下一页</a><%} else {%><a class="disabled">下一页</a><%}%><p>当前页:<%= currentPage %> / 共 <%= totalPages %> 页</p>
</div>
相关文章:
JSP+Servlet实现列表分页功能
分享一种最简单的JSPServlet实现分页的方式! 旧:无分页功能的查询列表功能,仅供参考! Servlet try {Connection conn null;PreparedStatement ps null;ResultSet rs null;List<Dept> arrayList null;conn DBUtil.get…...
操作系统存储器相关习题
1 为什么要配置层次式存储器? 设置多个存储器可以使存储器两端的硬件能并行工作; 采用多级存储系统特别是Cache技术,是减轻存储器带宽对系统性能影响的最佳结构方案; 在微处理机内部设置各种缓冲存储器,减轻对存储器存取的压力。…...
QUICK 调试camera-xml解析
本文主要介绍如何在QUICK QCS6490使能相机模组。QCS6490的相机基于CameraX的框架,只需通过配置XML文件,设置相机模组的相关参数,就可以点亮相机。本文主要介绍Camera Sensor Module XML和Camera Sensor XML配置的解析,这中间需要c…...
【linux】shell脚本编写基础
shell 脚本关键字: 1、变量定义:前后不能空格 输入: zhao"Joe" echo ${zhao} echo "I am ${zhao}" 输出: yuxin I am Joe2、echo 输出 输入: echo "123" 输出: 1233、readonly 定义变…...
STM32 外设简介
STM32 外设简介 STM32 是由意法半导体 (STMicroelectronics) 开发的一系列基于 ARM Cortex 内核的微控制器,广泛应用于嵌入式系统中。STM32 系列的一个重要特点是其丰富而强大的外设模块,支持多种接口和功能,能满足工业控制、物联网、消费电…...
Django-Vue3-Admin - 现代化的前后端分离权限管理系统
项目介绍 Django-Vue3-Admin是一个基于RBAC(Role-Based Access Control)模型的综合性基础开发平台,专注于权限控制,支持列级别的细粒度权限管理。该项目采用前后端分离架构,技术栈包括: 后端: Django Django REST …...
Cesium K-means自动聚合点的原理
Cesium K-means自动聚合点的原理 Cesium 是一个开源的 JavaScript 库,用于在 Web 环境中创建 3D 地球和地图应用。它能够处理地理空间数据,并允许开发者对大规模的地理数据进行可视化展示。在一些应用中,尤其是当处理大量地理坐标点时&#…...
Vue 项目中如何解决组件之间的循环依赖
前言 在大型 Vue 项目中,组件之间的关系可能会变得非常复杂,甚至会出现循环依赖的问题。循环依赖是指两个或多个模块互相依赖,形成一个闭环。这类问题会导致项目无法正常编译或运行,甚至可能引发意想不到的错误。本文将通过通俗易…...
交通流量预测:基于交通流量数据建立模型
✅作者简介:2022年博客新星 第八。热爱国学的Java后端开发者,修心和技术同步精进。 🍎个人主页:Java Fans的博客 🍊个人信条:不迁怒,不贰过。小知识,大智慧。 💞当前专栏…...
Hot100 - 搜索二维矩阵II
Hot100 - 搜索二维矩阵II 最佳思路: 利用矩阵的特性,针对搜索操作可以从右上角或者左下角开始。通过判断当前位置的元素与目标值的关系,逐步缩小搜索范围,从而达到较高的效率。 从右上角开始:假设矩阵是升序排列的&a…...
uart_pl011.c驱动API的zephyr测试
API概述 本次测试针对uart的uart_poll_in和uart_poll_outAPI进行测试, uart_poll_in static int pl011_poll_in(const struct device *dev, unsigned char *c)这是一个轮询方式的接收函数: 功能:检查 UART 是否有新数据到达,如…...
RPA:电商订单处理自动化
哈喽,大家好,我是若木,最近闲暇时间较多,于是便跟着教程做了一个及RPA,谈到这个,可能很多人并不是很了解,但是实际上,这玩意却遍布文末生活的边边角角。话不多说,我直接上…...
小程序 - 个人简历
为了让招聘人员快速地认识自己,可以做一个“个人简历”微信小程序, 展示自己的个人信息。 下面将对“个人简历”微信小程序进行详细讲解。 目录 个人简历 创建图片目录 页面开发 index.wxml index.wxss 功能实现截图 总结 个人简历 创建图片目录…...
MySQL自启动失败(MySQL不能开机自启)解决方案_MySQL开机自启疑难杂症解决,适用Win11/Win10
问题描述(MySQL 开机自启失败) 本文解决方法,在 windows10 、 windows11 系统中均可使用。 win11 安装 MySQL 后,不能开机自启。 在服务中,手动启动服务后,可正常使用,一点异常都没有。 或者…...
储存水..
问题描述: 给定m个非负整数表示每个宽度为1的柱子的高度图,计算按此排列的柱子下雨之后能储存多少水. 思路解析: 思考一下,什么样的位置能盛水?只有在当前柱子的左边和右边都比它高的情况下才能储存住水,而储水量和左侧最高柱及右侧最高柱有关.具体来说就是和左右两侧最矮的…...
Cmake 常用操作总结
CMakeLists.txt结构 总结该文件的主要结构 cmake_minimum_required(VERSION <version>) 指定CMake的最低版本,一般都是根据项目需要设定 cmake_minimum_required(VERSION 3.10) project(<name>) 定义项目的名称,放在CMake的开头 project(…...
Kylin Server V10 下 RocketMQ 主备自动切换模式部署
一、NameServer简介 NameServer 是一个注册中心,提供服务注册和服务发现的功能。NameServer 可以集群部署,集群中每个节点都是对等的关系,节点之间互不通信。 服务注册 Broker 启动的时候会向所有的 NameServer 节点进行注册,注意这里是向集群中所有的 NameServer 节点注册…...
DevOps工程技术价值流:GitLab源码管理与提交流水线实践
在当今快速迭代的软件开发环境中,DevOps(开发运维一体化)已经成为提升软件交付效率和质量的关键。而GitLab,作为一个全面的开源DevOps平台,不仅提供了强大的版本控制功能,还集成了持续集成/持续交付(CI/CD)…...
Vue 3 中实现页面特定功能控制
在开发 Vue 应用时,我们经常会遇到需要在特定页面启用或禁用某些功能的情况。本文将以 A父.vue 页面为例,探讨如何在点击汇总菜单时仅在该页面生效,而在其他页面不生效的问题。 1. 利用 Vue 3 的 provide 和 inject 实现状态传递 Vue 3 提供…...
VLC 播放的音视频数据处理流水线搭建
VLC 用 input_thread_t 对象直接或间接管理音视频播放有关的各种资源,包括 Access,Demux,Decode,Output,Filter 等,这个类型定义 (位于 vlc-3.0.16/include/vlc_input.h) 如下: struct input_thread_t {VLC_COMMON_MEMBERS };input_thread_t 是个抽象类型,VLC 中这个类…...
何时在 SQL 中使用 CHAR、VARCHAR 和 VARCHAR(MAX)
在管理数据库表时,考虑 CHAR、VARCHAR 和 VARCHAR(MAX) 是必不可少的。此外,使用正确的工具(例如dbForge Studio for SQL Server) ,与数据库相关的任务都会变得更加容易。它是针对 SQL Server 专业人员的强大的一体化解…...
学习笔记043——HashMap源码学习1
文章目录 1、HashMap2、Hashtable3、TreeMap4、HashMap 底层结构4.1、什么是红黑树? 1、HashMap HashMap key 是不能重复的,value 可以重复 底层结构 key-value 进行存储,key-value 存入到 Set 中,再将 Set 装载到 HashMap pack…...
单点登录原理
允许跨域–>单点登录。 例如https://www.jd.com/ 同一个浏览器下:通过登录页面产生的cookie里的一个随机字符串的标识,在其他子域名下访问共享cookie获取标识进行单点登录,如果没有该标识则返回登录页进行登录。 在hosts文件下面做的域名…...
【随笔】AI大模型对软件开发的影响
随着 AI 技术的不断发展,AI大模型正在重塑软件开发流程,从代码自动生成到智能测试,未来,AI 大模型将会对软件开发者、企业,以及整个产业链都产生深远的影响。欢迎探讨 AI 是如何重塑软件开发的各个环节以及带来的新的流…...
JAVA中接口类和抽象类的区别
在Java中,接口(Interface)和抽象类(Abstract Class)都是实现抽象概念的方式,但它们之间存在一些关键的区别: 1. 定义和声明 抽象类: 使用abstract关键字声明。可以包含构造方法、成…...
【AI系统】昇腾 AI 架构介绍
昇腾 AI 架构介绍 昇腾计算的基础软硬件是产业的核⼼,也是 AI 计算能⼒的来源。华为,作为昇腾计算产业⽣态的⼀员,是基础软硬件系统的核⼼贡献者。昇腾计算软硬件包括硬件系统、基础软件和应⽤使能等。 而本书介绍的 AI 系统整体架构&#…...
uniapp input只输入一个字符就自动失去焦点
下面一段代码在每次输入后自动失去焦点,这是因为绑定的:key是动态的,输入改变后都需要重新刷新渲染,这是造成input只能输入一次就自动失去焦点的原因。 <view class"" v-for"(item, index) in phoneList" :key"…...
定时/延时任务-ScheduledThreadPoolExecutor的使用
文章目录 1. 概要2. 固定速率和固定延时2.1 固定速率2.2 固定延时 3. API 解释3.1 schedule3.2 固定延时 - scheduleWithFixedDelay3.2 固定速率 - scheduleWithFixedDelay 4. 小结 1. 概要 前三篇文章的地址: 定时/延时任务-自己实现一个简单的定时器定时/延时任…...
自编码器(一)
其实自编码器也可以算是自监督学习的一环,因 此我们可以再简单回顾一下自监督学习的框架。如图1.1所示,首先你有大量的没有标注的 数据,用这些没有标注的数据,你可以去训练一个模型,你必须设计一些不需要标注数据的 任…...
Spring Cloud(Kilburn 2022.0.2版本)系列教程(五) 服务网关(SpringCloud Gateway)
Spring Cloud(Kilburn 2022.0.2版本)系列教程(五) 服务网关(SpringCloud Gateway) 一、服务网关 1.1 什么是网关 在微服务架构中,服务网关是一个至关重要的组件。它作为系统的入口,负责接收客户端的请求,并将这些请求路由到相应的后端服务…...
建设用地办理信息网站/2022最新免费的推广引流软件
一 Undo Log Undo Log是为了实现事务的原子性,在MySQL数据库InnoDB存储引擎中,还用Undo Log来实现多版本并发控制(简称:MVCC)。 1 事务的原子性(Atomicity) 事务中的所有操作,要么全部完成,要么不做任何操作&#…...
手机免费平面设计软件/南昌seo网站排名
由于信道管理器在客户端和服务端所起的不同作用,分为信道监听器和信道工厂。和服务端的信道监听其相比,处于客户端的信道工厂显得简单。从名称就可以看得出来,信道工厂的作用就是单纯的创建用于消息发送的信道。我们先来看看与信道工厂相关的…...
中国核工业第二二建设有限公司是国企吗/百度seo排名优
smartsvn9破解及license文件 第一步:去官网下载自己系统smartsvn版本文件 下载地址:http://www.smartsvn.com/download 第二步:破解 (1) 将文件解压到系统路径:/opt/smartsvn (2) 打开smartsvn,选中license注册 …...
网页设计网站导航怎么弄红色字体的/企业关键词优化最新报价
身为人品从来都是只爆炸不积攒的万年黑脸,我表示Ubuntu系统下的workbench也在刚打开电脑的时候出现了闪退的状况,直接摧毁了一张没来得及保存的数据库表,心塞。由是,我开启了直接在终端上打代码的苦逼日子。——尼古拉斯君华日记。…...
爱网恋的男生/重庆网络seo
先说一下什么是Ucenter,顾名思义它是“用户中心”。UCenter是Com服务器enz旗下各个产品之间信息直接传递的一个桥梁,通过UCenter可以无缝整合Com服务器enz系列产品,实现用户的一站式登录以及社区其他数据的交互。Ucenter 通信基本过程如下:1.从用户xxx在某一应用程序…...
网站gif素材/百度seo教程
场景分为使用默认 GC,以及使用 ZGC 或者 Shenandoah GC。默认 GC 情况下,虽然超过 32G 是可行的,但是在这个场景下缺乏 JVM 调优经验,可供参考的实例不多,需要对 JVM 有全面深入的理解才能调优好。但是大部分应用可以水…...