Hibernate的分页技术

本文详细介绍了Hibernate分页技术的应用方法,包括如何设置查询参数FirstResult和MaxResults以实现高效分页,同时还提供了实例代码帮助理解。
Hibernate的分页技术是透明的,,你理解最好,不能理解先用着呗。。 
说白了就是查询语句中你不用写上一堆的分页语句了,Hibernate已经实现了,但最终的查询跟手工的查询没两样,oracle用的还是rownum,mysql还是用的limit。
蔡华江 (资深架构师) 2009-10-21
Java代码   收藏代码
  1. /** 
  2.      * 基本分页方法;取得实际资源,不带查询条件,这里的 entityClass.getName()为取得对象名,如:USER对象。 
  3.      */  
  4.     @SuppressWarnings("unchecked")  
  5.     public List resouce(Integer FirstResult,Integer MaxResults){      
  6.   
  7.         String querySentence = "from"+" "+ entityClass.getName();     
  8.         Query query = getSession().createQuery(querySentence);     
  9.         query.setFirstResult(FirstResult)  
  10.              .setMaxResults(MaxResults);     
  11.         return query.list();  
  12.       }  



这里有2个参数,一个是FirstResult,意思是从第几个开始,如果你要查从第一个开始,就填0(应该是从0+1开始的)。 

第二个参数是,MaxResults,就是从FirstResult开始取几个。比如:如果你的FirstResult为1,那么如果你想取十个的话,那么此时的MaxResults为 FirstResult+10。
treblesoftware (初级程序员) 2009-10-21
你需要做2样事情。 

第一,你需要一个PAGE对象,里面封装一些基本的参数,比如:当前的页数,下一页,上一页,总页数。

第二,你需要在JSP页面去构件一个用于交互的环境。 


举例: 
Java代码   收藏代码
  1. public String adminBlogPassageManage(){  
  2.           
  3.         intRowCount = blogPassageService.total("order by id");// 获得总行数  
  4.         total = (intRowCount / 20)+1;// 总页数 等于总行数除以每页显示的行数(5).  
  5.         if (total <= 0)  
  6.             total = 1;  
  7.   
  8.         if (pageNo > total)  
  9.             pageNo = total;  
  10.             int i = (pageNo - 1) * 20;  
  11.   
  12.         int FirstResult = i;// 从当前页的首个数据开始  
  13.         int MaxResults = 20;// 从当前FirstResult自加10.  
  14.         blogPassages = blogPassageService.AdminListBlogPassageByPage(FirstResult, MaxResults,"order by catergoryId");  
  15.         return SUCCESS;  
  16.     }  


这段代码显示了,根据几个参数获取页面需要的LIST。因为我用的是STRUTS2自己写的一个分页主件,所以简单了很多,但是意思都是参不多的,你到网上找找JSP分页的主件,到时候用这个思路,就可以解决问题了。 
treblesoftware (初级程序员) 2009-10-21
对不起,上面写错了。 


Java代码   收藏代码
  1. intRowCount = blogPassageService.total("order by id");// 获得总行数    
  2.        total = (intRowCount / 5)+1;// 总页数 等于总行数除以每页显示的行数(5).    
  3.        if (total <= 0)    
  4.            total = 1;    
  5.    
  6.        if (pageNo > total)    
  7.            pageNo = total;    
  8.            int i = (pageNo - 1) * 5;    


把20改为5。
treblesoftware (初级程序员) 2009-10-21
看来哥们都给你说的很明白了。小弟也就不在言辞了。
gaoyangboy (初级程序员) 2009-10-21
我晕。我已经说的很明白了。  你不要急,要慢慢的去理解,一开始是有点抽象。你得知道页面需要几个参数,之后根据这几个参数算出FirstResult,MaxResults,之后传给HIBERNATE就行了。
treblesoftware (初级程序员) 2009-10-21
我最喜欢传递以下三个参数 
start从那里开始分;limit这一页分多少个;total总记录数 

这个我特别喜欢,清楚,有了这三个参数,其余的多少页,开始页都可以算得出来。 
hibernate中用的的参数就是start和limit 
你要是不理解,最好自己写例子,就传递这三个参数,然后在页面中计算出来其余的值。。
蔡华江 (资深架构师) 2009-10-21
可以使用这个分页的类作为辅助,设置当前页(currentPage)每页显示记录数(pageSize),再设置总记录数(recordCount) 
Java代码   收藏代码
  1. import java.util.List;  
  2.   
  3. public class Page {  
  4.   
  5.     private int pageSize;  
  6.     private int currentPage;  
  7.     private int pageCount;  
  8.     private int recordCount;  
  9.     private int nextPage;  
  10.     private int beforePage;  
  11.     private List result;  
  12.       
  13.     public List getResult() {  
  14.         return result;  
  15.     }  
  16.     public void setResult(List result) {  
  17.         this.result = result;  
  18.     }  
  19.     public int getPageSize() {  
  20.         return pageSize;  
  21.     }  
  22.     public void setPageSize(int pageSize) {  
  23.         this.pageSize = pageSize;  
  24.     }  
  25.     public int getCurrentPage() {  
  26.         return currentPage;  
  27.     }  
  28.     public void setCurrentPage(int currentPage) {  
  29.         this.currentPage = currentPage;  
  30.     }  
  31.     public int getPageCount() {  
  32.         return pageCount;  
  33.     }  
  34.     public void setPageCount(int pageCount) {  
  35.         this.pageCount = pageCount;  
  36.     }  
  37.     public int getRecordCount() {  
  38.         return recordCount;  
  39.     }  
  40.     public void setRecordCount(int recordCount) {  
  41.         this.recordCount = recordCount;  
  42.         if (recordCount % this.pageSize == 0) {  
  43.             this.pageCount = recordCount / this.pageSize;  
  44.         } else {  
  45.             this.pageCount = recordCount / this.pageSize + 1;  
  46.         }  
  47.         if (this.pageCount == 1) {  
  48.             this.nextPage = 1;  
  49.             this.beforePage = 1;  
  50.             this.currentPage = 1;  
  51.         } else if (this.currentPage >= this.pageCount) {  
  52.             this.currentPage = this.pageCount;  
  53.             this.nextPage = this.pageCount;  
  54.             this.beforePage = this.pageCount - 1;  
  55.         } else if (this.currentPage < 1) {  
  56.             this.currentPage = 1;  
  57.             this.beforePage = 1;  
  58.             this.nextPage = 2;  
  59.         } else {  
  60.             if (this.currentPage == 1) {  
  61.                 this.beforePage = 1;  
  62.             } else {  
  63.                 this.beforePage = this.currentPage - 1;  
  64.             }  
  65.             this.nextPage = this.currentPage + 1;  
  66.         }  
  67.     }  
  68.     public int getNextPage() {  
  69.         return nextPage;  
  70.     }  
  71.     public void setNextPage(int nextPage) {  
  72.         this.nextPage = nextPage;  
  73.     }  
  74.     public int getBeforePage() {  
  75.         return beforePage;  
  76.     }  
  77.     public void setBeforePage(int beforePage) {  
  78.         this.beforePage = beforePage;  
  79.     }  
  80. }  
lzysystem (初级程序员) 2009-10-21
给你推荐一篇文章是robbin在05年写的,后面有几个跟帖的也都有很大的学习和参考价值,http://www.iteye.com/topic/14657,我现在用的分页是在把这个帖子和跟帖看了好多遍之后做出来的
01404421 (高级程序员) 2009-10-22
我也来说两句, 
分页就是把一整个数据集分成几份来显示,每一份显示几条,你先想清楚,你每一份有几条数据,然后再拿张纸拿张笔,来算,第一份是从第几条开始,到第几条结束,第二份从第几条开始,到第几条结束,这个每一份显示几条呢,就是大家说的pageSize,第一份,第二份。。。。。这个第几份呢,就是第几页,而上一页呢,就是比如我现在到了第二页,我想去看第一页的数据,那是不是当前的页减一,就成了第一页了,对吧,这是有规律的,你从数据库里面拿出来的只是当前要显示的数据,和总共的数据量,至于当前第几页,从第几条开始显示,都是你自己算出来的,与数据库无关,你拿到当前要显示的数据集后,就是一个List,把这个List可以先放到一个自定义对象中再放到request中,也可以直接放到request中,都可以,这个List中的每一个元素就是一个对象(因为你用的是Hibernate),这个对象就是与你查询的表相映射的那个对象,然后在jsp页面中就从request中拿出这个集合(知道怎么拿吧,不知道就去学jsp),再使用jstl或者是其他的循环标签,基本上就可以使用了,应该能看得懂吧
wangdgsc (初级程序员) 2009-10-22
先别想Hibernate,先去搞个jdbc分页,把分页搞清楚了,再去看Hibernate,那不过是换一种简单点儿的实现方式,本质不变的
wangdgsc (初级程序员) 2009-10-22
我之前用的是struts1+spring+hibernate做的一个小项目,我用的分页代码你参考一一下:http://www.netded.com/read-htm-tid-4336.html
代码转载自:https://pan.quark.cn/s/8ce4326d996e 对于在 CentOS 7 系统中修改网卡配置文件后无法使设置生效的情况,经过实践验证,可以通过使用 nmcli 命令来进行调整。完成修改之后,需要重新启动虚拟机以使更改生效,这样操作流程即告完成。如果设置仍然无法生效,则表明虚拟机在启动过程中所获取的 IP 地址配置并非针对 eth0,此时可以对其它网卡的配置文件进行修改或将其移除。在 CentOS 7 系统中,网络配置的管理机制与早期版本存在差异,主要体现为采用了 Network Manager 服务来负责网络接口的管理。在某些情形下,尽管修改了 `/etc/sysconfig/network-scripts` 目录下的 `ifcfg-eth0` 文件,但网络配置却能即时生效。此类问题的发生通常源于 CentOS 7 采用了不同于以往的配置读取方法。接下来将具体阐述如何借助 nmcli 命令来处理这一挑战。 以 root 用户身份登录系统并打开终端界面。nmcli 是 Network Manager 提供的命令行界面工具,它支持在命令行环境下执行网络连接的建立、编辑、查询及管理任务。针对修改 eth0 网卡配置的需求,可以遵循以下步骤进行操作: 1. 导航至 `/etc/sysconfig/network-scripts` 目录: ``` cd /etc/sysconfig/network-scripts ``` 2. 检查该目录内是否存在 `ifcfg-eth0.bak` 文件,该备份文件可能是先前调整配置时遗留下来的,若存在可能造成冲突。若发现该文件,可以选择将其删除: ``` [root@localhost netw...
代码转载自:https://pan.quark.cn/s/46fd08fb879c 网管教程 从入门到精通软件篇 ★一。★详尽的xp修复控制台指令及其应用!!! 放入xp(2000)的光盘,安装时选择R,执行修复! Windows XP(涵盖 Windows 2000)的控制台指令是在系统遭遇某些意外状况时的一种极具效用的诊断、检测以及恢复系统功能的工具。笔者确实一直期望能够将这方面的指令进行归纳,此次由老范辛苦整理了这份极具价值的秘籍。 Bootcfg bootcfg 命令用于启动配置与故障恢复(对大多数计算机而言,即 boot.ini 文件)。 带有特定参数的 bootcfg 命令仅在运用故障恢复控制台时方可使用。能够在命令行界面下运用带有不同参数的 bootcfg 命令。 用法: bootcfg /default 设定默认引导选项。 bootcfg /add 向引导清单中增添 Windows 安装。 bootcfg /rebuild 重复整个 Windows 安装流程并让用户选择需添加的项目。 注意:运用 bootcfg /rebuild 之前,应先借助 bootcfg /copy 命令备份 boot.ini 文件。 bootcfg /scan 探查用于 Windows 安装的全部磁盘并展示结果。 注意:这些结果被静态存储,并用于当前会话。若在当前会话期间磁盘配置发生变动,为获取更新的探查结果,必须先重启计算机,然后再次探查磁盘。 bootcfg /list 列示引导清单中已有的项目。 bootcfg /disableredirect 在启动引导程序中禁用重定向。 bootcfg /redirect [ PortBaudRrate] |[ useBio...
代码下载链接: https://pan.quark.cn/s/fc524f791b68 AA制程,即Active Alignment,被理解为主动对准,是一种用于确定零部件装配中相对位置的方法。在摄像头封装阶段,涉及图像传感器、镜座、马达、镜头、线路板等多个部件的重复组装,而传统的封装设备如CSP及COB等,均是依据设备设定的参数进行零部件的移动装配,因而零部件的叠加误差会逐渐增大,最终在摄像头上表现为拍照最清晰的位置可能偏离画面中心、四边清晰度不均等现象。伴随智能手机和其他高端电子产品的普及,摄像头模组的性能正日益受到重视。高分辨率、卓越的低光表现以及稳定视频输出是现代用户所期望的。在摄像头模组的制造环节,各部件的精准定位对成像质量具有决定性作用。因此,一种名为“AA制程”(Active Alignment)的前沿技术被开发出来,成为摄像头精密对准的核心技术。 AA制程,即Active Alignment,是一种在摄像头封装过程中应用的主动对准方法。该方法在多个组件装配阶段发挥作用,涵盖图像传感器、镜座、马达、镜头和线路板等部件。传统的封装方式,例如CSP(Chip Scale Package)和COB(Chip On Board),依赖于设备预设的参数进行组装,但随着组件数量的增加,误差也会累积,最终影响摄像头的表现。例如在成像质量上可能出现中心位置偏移、四角清晰度不一致等问题。 AA制程技术的核心在于实时监测与主动调整。在组装过程中,它借助先进的检测设备持续监控半成品的状态,并根据实时信息对组装部件进行精确修正,从而显著降低装配误差。通过这种技术,能够确保摄像头模组中各组件的相对位置准确无误,从而使得最终的成像效果更加稳定,特别是在中心区域和四角的清晰度上...
内容概要:本文介绍了一套基于Matlab实现的光子晶体90度弯曲波导的二维时域有限差分法(2D FDTD)仿真代码,旨在通过数值模拟手段深入研究光子晶体波导中的光传播特性。该资源聚焦于电磁场与光子学领域的仿真技术应用,系统实现了FDTD算法在复杂介质结构中的建模过程,涵盖空间网格剖分、时间步进迭代、完美匹配层(UPML)边界条件处理、总场散射场(TFSF)激励源设置、介电常数分布定义及电磁场演化可视化等核心模块,能够有效分析光在90度弯曲波导中的传输效率、模式分布与反射损耗等关键性能指标。; 适合人群:具备电磁场理论基础和Matlab编程能力的研究生、科研人员以及从事光子晶体器件设计与仿真的工程技术人员。; 使用场景及目标:①用于教学演示FDTD方法的基本原理与算法流程,帮助理解麦克斯韦方程的离散化求解过程;②支撑科研工作中对光子晶体弯曲波导结构的传输特性进行仿真分析与性能优化;③作为开发更复杂光子集成器件(如分束器、滤波器)数值仿真工具的基础框架; 阅读建议:建议使用者结合经典FDTD教材(如Taflove著作)深入理解算法理论,并在Matlab环境中逐模块调试代码,重点关注电场与磁场的交替更新过程、UPML吸收边界的设计实现以及TFSF源的引入方式,从而全面提升对时域电磁仿真机制的掌握与应用能力。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值