`
soia
  • 浏览: 4837 次
  • 性别: Icon_minigender_1
  • 来自: System
最近访客 更多访客>>
社区版块
存档分类
最新评论

Java分页代码(JFIS)

    博客分类:
  • ajax
阅读更多
TpageList类
package jfis.util;

import java.util.List;

publicclass TPageList {
        private TPages page=null;         //分页对象
        private List objectList=null;    //对象集合
        private String pageStr="";      //分页字符串
       
        public List getObjectList() {
                returnobjectList;
        }
        publicvoid setObjectList(List objectList) {
                this.objectList = objectList;
        }
       
        public TPages getPage() {
                returnpage;
        }
        publicvoid setPage(TPages page) {
                this.page = page;
                pageStr=page.getLastPageBreak();
        }
        public String getPageStr() {
                returnpageStr;
        }
        publicvoid setPageStr(String pageStr) {
                this.pageStr = pageStr;
        }

}
Tpages类
package jfis.util;

import javax.servlet.http.HttpServletRequest;

publicclass TPages {
        private String fileName="";     
        privateintpageSize=2;           //页大小
        privateintallPage=1;             //总页数
        privateintcPage=1;               //当前页
        privateintsPage=1;               //当前页开始记录数
        privateintallRecord=1;          //总记录数
        private String lastPageBreak="";   //分页字符串
        privateinta ;//分拆list结果集的变量(相当与游标)。可从list中的确定位置开始读数据
       
       
          
//              String bian = request.getParameter("aaa")==null?"0":"5";
//              this.a = new Integer(bian);
       
               
        publicint getA() {
                returna;
        }

        publicvoid setA(int a) {
                this.a = a;
        }

        public TPages(){
               
        }
       
        public TPages(String fileName,HttpServletRequest request){
               
                this.fileName=fileName;
                //获得当前页
                String cPageStr = request.getParameter("cpage")==null?"1":request.getParameter("cpage");
                this.a = request.getParameter("aaa")==null ? 0 : new Integer(request.getParameter("aaa"));
                int cPageInt = 0;
                try
                {
                        cPageInt = Integer.parseInt(cPageStr);
                }catch(Exception e){
                        System.out.println("com.s6.util.Pages = "+e.getMessage());
                        cPageInt = 1;
                }finally{
                        cPage = cPageInt;
                }
        }
       
        //计算总页数,判断当前页的合法性,计算当前页的开始记录数,生成分页字符串
        publicvoid doPage(){
                //计算总页数
                this.allPage=(int)(this.allRecord+this.pageSize-1)/this.pageSize;
               
                //判断当前页的合法性
                if(this.cPage<0){
                        this.cPage=1;
                }
                if(this.cPage>this.allPage){
                        this.cPage=this.allPage;
                }
               
                //计算当前页开始记录数
                this.sPage=(this.cPage-1)*this.pageSize+1;
               
               
               
                //生成分页字符串
                StringBuffer str=new StringBuffer();
                //判断是否有问号“?”
                if(this.fileName.indexOf("?")==-1){
                        this.fileName=this.fileName+"?1=1";
                }
               
                str.append("<table width=\"100%\" height=\"100%\">");
               
                //添加表单
                str.append("<form name=\"pagelist\" method=\"post\" action=\"");
                str.append(this.fileName+"\">");
               
                str.append("<tr><td width=\"100%\" height=\"100%\" align=\"right\" valign=\"middle\">");
               
                str.append("总纪录数"+this.allRecord+"条");
                str.append("&nbsp;");
                //首页
                if(this.cPage>1){
                        str.append("<a href="+this.fileName+"&cpage=1>首页</a>");
                }else{
                        str.append("首页");
                }
                str.append("&nbsp;");
               
                //上一页
                if(this.cPage>1){
                        str.append("<a href=");
                        str.append(this.fileName+"&cpage=");
                        str.append(this.cPage-1);
                        str.append("&aaa=");
                        str.append(this.a-5);
                        str.append(">上一页</a>");
                }else{
                        str.append("上一页");
                }
                str.append("&nbsp;");
               
                //下一页
                if(this.cPage<this.allPage){
                        str.append("<a href=");
                        str.append(this.fileName+"&cpage=");
                        str.append(this.cPage+1);
                        str.append("&aaa=");
                        str.append(this.a+5);
                        str.append(">下一页</a>");
                }else{
                        str.append("下一页");
                }
                str.append("&nbsp;");
               
                //末页
                if(this.cPage<this.allPage){
                        str.append("<a href=");
                        str.append(this.fileName+"&cpage=");
                        str.append(this.allPage);
                        str.append(">末页</a>");
                }else{
                        str.append("末页");
                }
                str.append("&nbsp;");
               
                //第几页
                str.append("第");
                str.append(this.cPage);
                str.append("页");
                str.append("&nbsp;");
               
                //共几页
                str.append("共");
                str.append(this.allPage);
                str.append("页");
                str.append("&nbsp;");
               
                //跳转页
                for(int i=1;i<=this.allPage;i++){
                        str.append("&nbsp;");
                       
                        if(i==this.cPage){
                                str.append(i);
                        }else{
                                str.append("<a href=");
                                str.append(this.fileName+"&cpage=");
                                str.append(i);
                                str.append(">"+i+"</a>");
                        }
                }
               
                str.append("</td></tr></form>");
                str.append("</table>");
               
                lastPageBreak=str.toString();
       
        }
       
               
       
        publicint getAllPage() {
                returnallPage;
        }
        publicvoid setAllPage(int allPage) {
                this.allPage = allPage;
        }
        publicint getCPage() {
                returncPage;
        }
        publicvoid setCPage(int page) {
                cPage = page;
        }
        public String getFileName() {
                returnfileName;
        }
        publicvoid setFileName(String fileName) {
                this.fileName = fileName;
        }
        public String getLastPageBreak() {
                returnlastPageBreak;
        }
        publicvoid setLastPageBreak(String lastPageBreak) {
                this.lastPageBreak = lastPageBreak;
        }
        publicint getPageSize() {
                returnpageSize;
        }
        publicvoid setPageSize(int pageSize) {
                this.pageSize = pageSize;
        }
        publicint getSPage() {
                doPage();
                returnsPage;
        }
        publicvoid setSPage(int page) {
                sPage = page;
        }
        publicint getAllRecord() {
                returnallRecord;
        }
        publicvoid setAllRecord(int allRecord) {
                this.allRecord = allRecord;
        }
       

}
DAO里的方法
// 分页
        public TPageList pageSearchlist(TPages pages, List list) {
                TPageList pageList = new TPageList();
                // 记录集总行数
                pages.setAllRecord(list.size());
                // rs用于保存从list中截取的记录
                List rs = new ArrayList();
                // 控制从list集合中的第几条开始读取,相当于游标
                int a = pages.getA();
                // for循环中"5"代表一次读出多少条数据:"a"控制从list集合中的第几条开始读取,相当于游标。
                for (int i = 0; i < 5 && a < list.size(); a++) {
                        rs.add(list.get(a));
                        i++;
                }
                Iterator iterator = rs.iterator();
                // 得到分页字符串
                pages.getSPage();
                int i = 0;// 循环变量
                // 判断记录总行数是否大于0,并循环创建USER对象
                if (pages.getAllRecord() > 0) {
                        do {
                                i++;
                        } while (iterator.hasNext() && i < pages.getPageSize());
                        pageList.setPage(pages);
                        pageList.setObjectList(rs);
                }
                return pageList;
        }
Action里的方法
public ActionForward pageSearchList(ActionMapping mapping, ActionForm form,
                        HttpServletRequest request, HttpServletResponse response) {

                TPages pages = new TPages(
                                "/JFIS_CompanyManager/client/outer.do?method=pageSearchList",
                                request);

                pages.setPageSize(5);

                TPageList pageList = iouter.pageSearchlist(pages, iouter.getAllOuter());
                request.setAttribute("outers", pageList);

                return mapping.findForward("outer_list");

        }
SSH分页
说明:分页的两个类不变,只变Action和DAO。
Action中
// 分页
        public ActionForward pageSearchList(ActionMapping mapping, ActionForm form,
                        HttpServletRequest request, HttpServletResponse response) {
                Pages pages = new Pages(                         "/JFIS_CompanyManager/client/outer.do?method=pageSearchList",request);
                pages.setPageSize(10);
                PageList pageList = iouter.outerList(pages);
                request.setAttribute("outers", pageList);
                return mapping.findForward("outer_list");
        }
DAO中
// 分页
        public PageList outerList(Pages pages) {
                PageList pageList = new PageList();
                List list = new ArrayList();
        /*开启一个HibernateSession对象*/
                Session session = this.getSession();
                Transaction t = session.beginTransaction();
                /*获得结果集*/
                Query query = session
                                .createQuery("from jfis.bean.JfisClientItem order by starttime desc");
                /*记录集总行数*/
                pages.setAllRecord(query.list().size());
                query.setFirstResult(pages.getSPage() - 1);
                query.setMaxResults(10);/*设置每页显示的记录数*/
                List rs = query.list();
                Iterator iterator = rs.iterator();
                /*得到分页字符串*/
                pages.getSPage();
                int i = 0;/*循环变量*/
                /*判断记录总行数是否大于0,并循环创建USER对象*/
                if (pages.getAllRecord() > 0) {
                        do {
                                list = rs;
                                i++;
                        } while (iterator.hasNext() && i < pages.getPageSize());
                        pageList.setPage(pages);
                        pageList.setObjectList(list);           
                        t.commit();/*事务提交*/
                        session.close();
                }
                return pageList;
        }

分享到:
评论

相关推荐

    大华无插件播放项目111

    大华无插件播放项目111

    Oracle 19c 数据库备份恢复与导入导出实战指南

    内容概要:本文详细介绍了Oracle 19c数据库的备份恢复和导入导出操作。首先概述了基本命令,然后分别讲述了三种工作方式(交互式、命令行、参数文件)和三种模式(表、用户、全库)。接着介绍了高级选项,如分割成多个文件、增量导出/导入、以SYSDBA进行导出/导入、表空间传输等。最后讨论了优化技巧,包括加快导出和导入速度的方法。还解决了一些常见问题,如字符集问题和版本问题。 适用人群:Oracle数据库管理员和相关技术人员。 使用场景及目标:适合在日常数据库管理和维护中进行数据备份、恢复、导入和导出操作,提高数据安全性和管理效率。 其他说明:文章内容丰富,涉及多种实用技巧,适用于不同场景下的具体操作,有助于提升工作效率。

    大数据旅游酒店大数据可视化项目

    基于Python Flask开发的旅游酒店大数据可视化项目,可以直接运行。 操作步骤: 1. 解压缩项目文件 2. 使用 pycharm打开项目 3. 运行项目中的app.py文件 注意:需要确保项目的Flask Python相关的环境已经搭建完成。

    模拟立体翻转效果,非Gallery实现.zip

    Android 毕业设计,Android 毕业设计,小Android 程设计,含有代码注释,新手也可看懂。毕业设计、期末大作业、课程设计、高分必看,下载下来,简单部署,就可以使用。 包含:项目源码、数据库脚本、软件工具等,该项目可以作为毕设、课程设计使用,前后端代码都在里面。 该系统功能完善、界面美观、操作简单、功能齐全、管理便捷,具有很高的实际应用价值。

    仿360 浮动小插件效果.zip

    Android 毕业设计,Android 毕业设计,小Android 程设计,含有代码注释,新手也可看懂。毕业设计、期末大作业、课程设计、高分必看,下载下来,简单部署,就可以使用。 包含:项目源码、数据库脚本、软件工具等,该项目可以作为毕设、课程设计使用,前后端代码都在里面。 该系统功能完善、界面美观、操作简单、功能齐全、管理便捷,具有很高的实际应用价值。

    基于stm32和openmv的电赛校赛自动泊车题目源码+文档设计报告

    基于stm32和openmv的电赛校赛自动泊车题目源码+文档设计报告,个人高分设计项目、经导师指导并认可通过的高分设计项目,评审分99分,代码完整确保可以运行,小白也可以亲自搞定,主要针对计算机相关专业的学生和需要项目实战练习的学习者。 基于stm32和openmv的电赛校赛自动泊车题目源码+文档设计报告基于stm32和openmv的电赛校赛自动泊车题目源码+文档设计报告基于stm32和openmv的电赛校赛自动泊车题目源码+文档设计报告基于stm32和openmv的电赛校赛自动泊车题目源码+文档设计报告基于stm32和openmv的电赛校赛自动泊车题目源码+文档设计报告基于stm32和openmv的电赛校赛自动泊车题目源码+文档设计报告基于stm32和openmv的电赛校赛自动泊车题目源码+文档设计报告基于stm32和openmv的电赛校赛自动泊车题目源码+文档设计报告个人高分设计项目、经导师指导并认可通过的高分设计项目,评审分99分,代码完整确保可以运行,小白也可以亲自搞定,主要针对计算机相关专业的学生和需要项目实战练习的学习者。 个人高分设计项目、经导师指导并认可通过的高分设

    棉花检测20-YOLO(v5至v9)、COCO、CreateML、Darknet、Paligemma、TFRecord、VOC数据集合集.rar

    棉花检测20-YOLO(v5至v9)、COCO、CreateML、Darknet、Paligemma、TFRecord、VOC数据集合集.rar棉-V2释放 ============================= *与您的团队在计算机视觉项目上合作 *收集和组织图像 *了解非结构化图像数据 *注释,创建数据集 *导出,训练和部署计算机视觉模型 *使用主动学习随着时间的推移改善数据集 它包括406张图像。 以可可格式注释棉花。 将以下预处理应用于每个图像: 没有应用图像增强技术。

    javaweb社区医院挂号系统-lw.zip

    项目包含前后台完整源码。 项目都经过严格调试,确保可以运行! 具体项目介绍可查看博主文章或私聊获取 助力学习实践,提升编程技能,快来获取这份宝贵的资源吧!

    python-3.11.11-amd64.exe

    windwos环境下python 3.11系列64位安装包,仅推荐个人学习、开发、娱乐或者测试环境下使用。

    基于ssm的精品酒销售管理系统+jsp源代码(完整前后端+mysql+说明文档+LW).zip

    使用精品酒销售管理系统的用户分管理员和用户两个角色的权限子模块。 管理员所能使用的功能主要有:主页、个人中心、用户管理、商品分类管理、商品信息管理、系统管理、订单管理等。 用户可以实现主页、个人中心、我的收藏管理、订单管理等。 前台首页可以实现商品信息、新闻资讯、我的、跳转到后台、购物车等。 项目包含完整前后端源码和数据库文件 环境说明: 开发语言:Java 框架:ssm,mybatis JDK版本:JDK1.8 数据库:mysql 5.7 数据库工具:Navicat11 开发软件:eclipse/idea Maven包:Maven3.3 服务器:tomcat7

    Video_2024-12-18_000023.wmv

    Video_2024-12-18_000023.wmv

    ppt最終版asasaadd

    ppt最終版asasaadd

    计算机图形学试卷第一套

    计算机图形学期末考试

    springboot-基于SpringBootVue的家具商城系统设计与实现.zip

    springboot-基于SpringBootVue的家具商城系统设计与实现.zip

    PenTablet_5.2.4-5.zip

    PenTablet_5.2.4-5.zip

    基于ssm的企业人力资源管理系统源代码(完整前后端+mysql+说明文档+LW).zip

    考虑了企业管理者的实际工作环境和需求,最终将人力资源系统划分为5个部分,即登录模块、组织发展模块、员工团队模块、合同管理模块、党建管理模块。 环境说明: 开发语言:Java 框架:ssm,mybatis JDK版本:JDK1.8 数据库:mysql 5.7 数据库工具:Navicat11 开发软件:eclipse/idea Maven包:Maven3.3 服务器:tomcat7

    QT5.12.9音乐播放器MP3 免费下载交流学习

    QT音乐播放器MP3 可点击播放可上一首下一首可调节音量 可暂停可上传音乐

    椅子检测6-YOLO(v5至v9)、COCO、CreateML、Darknet、Paligemma、TFRecord、VOC数据集合集.rar

    椅子检测6-YOLO(v5至v9)、COCO、CreateML、Darknet、Paligemma、TFRecord、VOC数据集合集.rar对象检测实验室-V1 2023-08-21 2:28 PM ============================= *与您的团队在计算机视觉项目上合作 *收集和组织图像 *了解和搜索非结构化图像数据 *注释,创建数据集 *导出,训练和部署计算机视觉模型 *使用主动学习随着时间的推移改善数据集 对于最先进的计算机视觉培训笔记本,您可以与此数据集一起使用 该数据集包括997张图像。 对象以可可格式注释。 将以下预处理应用于每个图像: *像素数据的自动取向(带有Exif-Arientation剥离) *调整大小为640x640(拉伸) 应用以下扩展来创建每个源图像的3个版本: *将盐和胡椒噪声应用于10%的像素

    Python项目-实例-13 截图工具.zip

    Python课程设计,含有代码注释,新手也可看懂。毕业设计、期末大作业、课程设计、高分必看,下载下来,简单部署,就可以使用。 包含:项目源码、数据库脚本、软件工具等,该项目可以作为毕设、课程设计使用,前后端代码都在里面。 该系统功能完善、界面美观、操作简单、功能齐全、管理便捷,具有很高的实际应用价值。

    Altas PF拧紧枪 OP协议,开发协议

    Altas PF拧紧枪 OP协议,开发协议

Global site tag (gtag.js) - Google Analytics