ICode9

精准搜索请尝试: 精确搜索
首页 > 编程语言> 文章详细

java – 客户端排序Hibernate分页?

2019-07-26 21:01:27  阅读:177  来源: 互联网

标签:java gwt hibernate pagination


我使用GWT for UI和Hibernate / Spring for buisness-layer.以下GWT小部件用于显示记录.(http://collectionofdemos.appspot.com/demo/com.google.gwt.gen2.demo.scrolltable.PagingScrollTableDemo/PagingScrollTableDemo.html).我假设排序是在客户端完成的.

我没有检索整个结果集,因为它很庞大.
我用

principals = getHibernateTemplate().findByCriteria(criteria,
                    fromIndex, numOfRecords);

检索数据.在Hibernate层中没有排序标准.

此方法不能提供正确的行为,因为它只对客户端中的当前数据集进行排序.

这个问题的最佳解决方案是什么?

注意:我可以使用UI框架获取primary-Sort-column和其他排序列.
可能我可以使用hibernate层中的primary-sort-column对结果进行排序?

解决方法:

您需要在服务器上排序.

然后你可以:

>将完整的结果集发送到客户端并在客户端处理分页.问题是结果集可能很大,无法从db检索并发送到客户端.
>处理服务器端的分页.客户端和服务器一次只从db请求一个页面.那么问题是,每次向db请求特定页面时,您将反复订购相同的数据以提取第1页,第2页等.这可能是大型数据库的问题.
>在两者之间进行权衡(对于大型数据库):

>设置限制,比如300项
>服务器根据订单要求数据库获取前301个项目
>服务器将结果集(最多301项)保存在缓存中
>客户端逐页请求服务器
>服务器使用缓存处理分页
>如果有301个项目,则客户端显示“命中列表包含300多个项目.它已被截断”.

注1:通常,客户不关心他是否不能进入最后一页.您可以改进解决方案以首先计算总行数(此时不需要订购),以便您可以显示对用户更好的消息,例如“结果包含2023个元素,只能查看前300个元素”.

注意2:如果您在不使用任何订单标准的情况下逐页请求数据,则大多数db(至少Oracle)不保证任何排序.因此,如果您向数据库发出两个请求,则第1页和第2页中的项可能相同.如果多个项具有用于排序的相同值(例如,相同日期),则会出现同样的问题. db不保证具有相同值的元素之间的任何排序.如果是这种情况,我会建议使用PK作为最后的订单标准(例如ORDER BY date,PK),以便以一致的方式完成分页.

注3:我说的是客户端和服务器,但您可以根据您的具体情况调整该想法.

标签:java,gwt,hibernate,pagination
来源: https://codeday.me/bug/20190726/1547129.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有