一个简洁的针对mysql数据库的分页类:
import java.util.List;
import java.util.Map;
import javax.servlet.http.HttpServletRequest;
import com.prj.db.DBManager;
public class PageBreaker {
int intOffset;
int intTotal;
int intMaxLine;
List listResults;
int intTPages;
int intCPages;
String strPageQuery;
String strQuery;
String strQueryPart;
String strFilePath;
public PageBreaker() {
intMaxLine = 10;
}
public List pageBreakQuery(String sql, HttpServletRequest req) {
strFilePath = req.getRequestURI();
int intBeginofsql = sql.indexOf("FROM");
String strSQLAfterFrom = sql.substring(intBeginofsql, sql.length()).trim();
strQuery = sql;
strQueryPart = strSQLAfterFrom;
String sqlCount = "select count(0) total "+strQueryPart;
DBManager.log4gm.info("sqlCount: "+sqlCount);
List listCount = DBManager.queryDB(sqlCount);
for (int i = 0; i < listCount.size(); i++) {
Map map = (Map)listCount.get(i);
try {
intTotal = Integer.parseInt(map.get("total").toString());
} catch (Exception ex) {
intTotal = 0;
}
}
String strOffsetFromPage = req.getParameter("offset");
if (strOffsetFromPage == null)
intOffset = 0;
else
try {
intOffset = Integer.parseInt(strOffsetFromPage);
} catch (Exception ex) {
intOffset = 0;
}
intTPages = (int) Math.ceil((double) intTotal / (double) intMaxLine);
setIntTPages(intTPages);
intCPages = (int) Math.floor((double) intOffset / (double) intMaxLine + 1.0D);
setIntCPages(intCPages);
if (intTotal > 0) {
sqlCount = (new StringBuffer(strQuery)).append(
" LIMIT ").append(intOffset).append(" , ").append(intMaxLine).toString();
DBManager.log4gm.info((new StringBuilder("pageable sql: ")).append(sqlCount).toString());
listResults = DBManager.queryDB(sqlCount);
}
return listResults;
}
public int getIntArea(String strCpage,int intAll) {
int intOffIndex = 0;
int intOff= 0;
try {
intOff = Integer.parseInt(strCpage);
}catch (Exception e) {
}
if(intOff>0 && intOff<=intAll) {
intOffIndex = intMaxLine *(intOff-1);
}
return intOffIndex;
}
public int getIntCPages() {
return intCPages;
}
public int getIntTPages() {
return intTPages;
}
public void setIntCPages(int intCPages) {
this.intCPages = intCPages;
}
public void setIntTPages(int intTPages) {
this.intTPages = intTPages;
}
public String PageLegend(HttpServletRequest req,String pagesTotal) {
String str = "<form name=allpage action=\""+req.getContextPath()+"/product/productsave.jsp\" method=\"POST\" >"
+"<input type=\"hidden\" value=\"pageoff\" name=strstatus2><input type=\"hidden\" value=\""+pagesTotal+"\" name=pages>" +
"<li style=\"float:center; padding-left:8px; margin-top:-7px;\">";
int first = 0;
int next = intOffset + intMaxLine;
int prev = intOffset - intMaxLine;
int last = (intTPages - 1) * intMaxLine;
if (intOffset >= intMaxLine)
str = (new StringBuffer(str))
.append("<A href=")
.append(strFilePath).append("?offset=").append(first)
.append(">首页</A> ").toString();
else
str = (new StringBuffer(str)).append(" 首页 ")
.toString();
if (prev >= 0)
str = (new StringBuffer(str)).append(" <A href=")
.append(strFilePath).append("?offset=").append(prev)
.append(">前页</A> ").toString();
else
str = (new StringBuffer(str)).append(" 前页 ")
.toString();
if (next < intTotal)
str = (new StringBuffer(str)).append(" <A href=")
.append(strFilePath).append("?offset=").append(next)
.append(">后页</A> ").toString();
else
str = (new StringBuffer(str)).append(" 后页 ")
.toString();
if (intTPages != 0 && intCPages < intTPages)
str = (new StringBuffer(str)).append(" <A href=")
.append(strFilePath).append("?offset=").append(last)
.append(">尾页</A>").toString();
else
str = (new StringBuffer(str)).append(" 尾页 ")
.toString();
str = (new StringBuffer(str)).append(" 页次:").append(
getIntCPages()).append("/").append(getIntTPages()).append("页 ")
.toString();
str = (new StringBuffer(str)).append(intMaxLine)
.append("条/页 ").append("共").append(intTotal).append("条</li>")
.toString();
str = (new StringBuffer(str))
.append(" 到第<input style=\"width:60px; height:20px; border:1px #dbdbdb solid\" name=\"whichone\" type=\"text\" />页,")
// .append("<script language=\"javascript\">function getSelected(option){return(option);}")
.append("<input style=\"width:60px; height:20px; border:1px #dbdbdb solid\" type=\"submit\" value=\"跳转\"/></form>")
// .append(" onclick=\"javascript:alert(prodelete.whichone.value)\"/>")
// .append(strFilePath).append("?offset=prodelete.whichone.value'\"/>")
.toString();
return str;
}
}
在查询时调用即可:
StringBuffer strbf = getProductSQL(strLimitation);
List list = pk.pageBreakQuery(strbf.toString().trim(), req);
================
分享到:
相关推荐
2. 配置参数:PageBreaker提供了一系列可配置的选项,如分页标记、每页显示的字符或单词数、是否在分页处显示导航等。你可以根据自己的需求调整这些参数,确保分页效果符合预期。 3. 应用到内容:在编写或编辑页面...
总的来说,iText+Flying Saucer生成PDF文档时遇到的中文不显示和不自动换行问题,可以通过调整字体设置、优化CSS布局和正确使用PageBreaker类来解决。在实际开发中,要充分理解这两个库的工作原理,结合实际需求进行...
tables-3.6.1-cp39-cp39-win_amd64.whl
基于springboot大学生心理咨询平台源码数据库文档.zip
基于Java web 实现的仓库管理系统源码,适用于初学者了解Java web的开发过程以及仓库管理系统的实现。
基于springboot智能推荐旅游平台源码数据库文档.zip
内容概要:本文是一份详尽的Ruby语言教程,首先介绍了Ruby语言的基本信息和发展背景。接着详细讲解了Ruby的基础语法,如变量、数据类型、运算符、控制流等,并深入探讨了面向对象编程的关键概念,包括类、对象、继承、封装和多态。随后介绍了Ruby的一些高级特性,如模块、异常处理、迭代器和文件I/O操作。最后,讨论了Ruby在Web开发中的应用,尤其是与Rails框架的结合。每个部分都配有相应的代码示例,帮助读者更好地理解和实践。 适合人群:适用于初学者和有一定基础的程序员,特别是对Ruby语言感兴趣的人。 使用场景及目标:学习和掌握Ruby语言的各项基础知识和高级特性,为进一步进行Web开发或其他相关编程打下坚实的基础。 其他说明:教程中的每一部分内容都有详细的解释和代码示例,非常适合自学和教学使用。
GEE训练教程——Landsat5、8和Sentinel-2、DEM和各2哦想指数下载
基于springboot在线问诊系统源码数据库文档.zip
基于springboot的流浪猫狗救助系统源码数据库文档.zip
GEE训练教程
该资源内项目源码是个人的课程设计、毕业设计,代码都测试ok,都是运行成功后才上传资源,答辩评审平均分达到96分,放心下载使用! ## 项目备注 1、该资源内项目代码都经过严格测试运行成功才上传的,请放心下载使用! 2、本项目适合计算机相关专业(如计科、人工智能、通信工程、自动化、电子信息等)的在校学生、老师或者企业员工下载学习,也适合小白学习进阶,当然也可作为毕设项目、课程设计、作业、项目初期立项演示等。 3、如果基础还行,也可在此代码基础上进行修改,以实现其他功能,也可用于毕设、课设、作业等。 下载后请首先打开README.md文件(如有),仅供学习参考, 切勿用于商业用途。
本教程帮助您了解什么是 SQLite,它与 SQL 之间的不同,为什么需要它,以及它的应用程序数据库处理方式。需要的朋友们可以参考看看! SQLite是一个软件库,实现了自给自足的、无服务器的、零配置的、事务性的 SQL 数据库引擎。SQLite是一个增长最快的数据库引擎,这是在普及方面的增长,与它的尺寸大小无关。SQLite 源代码不受版权限制。 什么是 SQLite? SQLite是一个进程内的库,实现了自给自足的、无服务器的、零配置的、事务性的 SQL 数据库引擎。它是一个零配置的数据库,这意味着与其他数据库一样,您不需要在系统中配置。 就像其他数据库,SQLite 引擎不是一个独立的进程,可以按应用程序需求进行静态或动态连接。SQLite 直接访问其存储文件。 为什么要用 SQLite? 不需要一个单独的服务器进程或操作的系统(无服务器的)。 SQLite 不需要配置,这意味着不需要安装或管理。 一个完整的 SQLite 数据库是存储在一个单一的跨平台的磁盘文件。 SQLite 是非常小的,是轻量级的,完全配置时小于 400KiB,省略可选功能配置时小于250K
基于springboot学生选课系统源码数据库文档.zip
【Android UI】SurfaceView中使用 Canvas 绘制可缩放大图 ( 拖动和缩放相关的变量 | Canvas 绘图函数 | 手势识别 多点触控流程 | 拖动图片 | 缩放图片 ) 博客链接:https://blog.csdn.net/shulianghan/article/details/143950948 一、需求分析 和 核心要点 说明 1、需求说明 2、核心要点 - 拖动和缩放相关的变量 3、核心要点 - Canvas 绘图函数 4、核心要点 - 手势识别 多点触控流程 5、核心要点 - 拖动图片 6、核心要点 - 缩放图片 二、完整代码示例 1、环境说明 2、SurfaceView 完整代码 3、运行结果
基于springboot+web的二手闲置交易系统源码数据库文档.zip
GEE训练教程
该资源内项目源码是个人的课程设计、毕业设计,代码都测试ok,都是运行成功后才上传资源,答辩评审平均分达到96分,放心下载使用! ## 项目备注 1、该资源内项目代码都经过严格测试运行成功才上传的,请放心下载使用! 2、本项目适合计算机相关专业(如计科、人工智能、通信工程、自动化、电子信息等)的在校学生、老师或者企业员工下载学习,也适合小白学习进阶,当然也可作为毕设项目、课程设计、作业、项目初期立项演示等。 3、如果基础还行,也可在此代码基础上进行修改,以实现其他功能,也可用于毕设、课设、作业等。 下载后请首先打开README.md文件(如有),仅供学习参考, 切勿用于商业用途。
基于SpringBoot的宠物寄领养网站源码数据库文档.zip
基于springboot的电影院售票管理系统源码数据库文档.zip