MyException - 我的异常网
当前位置:我的异常网» Java Web开发 » jsp大数据量分页(现下的数据是接近9000条)

jsp大数据量分页(现下的数据是接近9000条)

www.MyException.Cn  网友分享于:2015-08-26  浏览:54次
jsp大数据量分页(现在的数据是接近9000条)
如题
现在做的一个网站有个项目和新闻
大概的数据都是9000以上
如果采用数据库分页 可能导致数据库频繁访问 服务器压力大 (类似门户站)
如果采用记录集的自带的分页 数据太多 客户机和网络压力 又太大

昨天查了一下午网上的资料
有个思路:首先在数据库里分页 比如分1000条一页 (即一次查询1000条)
  然后,从返回的1000条数据里进行记录集分页
问题:如何当用户点到最后一页的时候(即当前1000条记录,分出来的最后一个页的页码时再次调用数据库分页。同时,如果用户点了最后一页应该是显示总共9000条记录的最后一页还是????)

------解决方案--------------------
直接分页啊 用SQL语句控制多好
select top [pagesize] * from table where id not in ( select top [pagesize*(currentpage-1)] id from table [查询条件] order by id ) and [查询条件] order by id

你查全世界人的 DNA排列都 没问题
------解决方案--------------------
问题:如何当用户点到最后一页的时候(即当前1000条记录,分出来的最后一个页的页码时再次调用数据库分页。同时,如果用户点了最后一页应该是显示总共9000条记录的最后一页还是????)

你这样的需求好像就有点儿复杂了,你想先数据库分页,然后页面中在对记录集分页,提供最后一页的链接,点击时显示的是哪个最后一页?
呵呵,听了你的问题,我决的只能靠代码控制了。
首先数据库分页封装到记录集中,前台再对记录集分页显示,但是此时有一个问题,其实也是看你的需求了,我要是改变每页的显示条数的话,假如原来是每页10条,我显示100页就OK了,可是我改成每页30条,那再从这1000条记录集中分页的话,想想可就复杂了啊,需要做几个判断……
我觉得,这样的设计对自己或用户都不是太好的设计。
这样子,楼主又考虑到分页效率的问题,那我觉得,是不是可以借助一些分页控件,可能他们内部的控制,会比我们代码控制要好一些吧!
推荐一个:pager-taglib,不依赖任何框架,jdbc就可实现。
如有其它好的实现方式还望多多交流……
------解决方案--------------------
用多少查多少。

// 数量sql
public String getCountSql(String strwhere){
String sqlstr ="select count(*) from table";
if(!"".equals(strwhere) && strwhere != null){
sqlstr =sqlstr+" where "+strwhere;
}
return sqlstr;
}
// 记录sql:currpage当前页;rowsPerPage每页显示多少行
public String getListSql(int currpage,String strwhere,int rowsPerPage){
String sqlstr="select Top "+rowsPerPage+" id,name" ;
sqlstr = sqlstr + " from table";
sqlstr = sqlstr + " where (id not in(select top " + rowsPerPage * (currpage - 1);
if("".equals(strwhere)){
sqlstr = sqlstr + " id from TBdaby order by id desc)) ";
}
else{
sqlstr = sqlstr + " id from TBdaby where " +strwhere+ " order by id desc)) And "+strwhere;
}
sqlstr = sqlstr + " order by id desc ";
return sqlstr;
}
改成StringBuffer连接字符串。
------解决方案--------------------
楼主
我以前遇到和你一样的问题

后来我自己重新编写了分页的代码

就是你提供的那个思路

如果有9000条数据,
页面每页只显示100条,
那么我每次初始进入页面,就一次行查前1000条出来,
然后等用户点到10页的时候刚好是1000条的最后100条
点11的时候,就判断是不是页码超出了内存集合分页的页码,你在内存里保存了1000条,按100条一页
那么应该是10页,当超出11的时候就可以了,这里你需要自己写算法
仔细思考下就写出来了
问题就是
当按11页的时候,一定要判断读取后1000条数据到内存,如果点10页的时候,一定要判断,是否要重新读前1000条道存储里
麻烦就是在这里,自己要写算法判断他点的页数,到底属于哪个1000条数据的范围内
------解决方案--------------------
楼主可以把问题简化一下考虑..
 建设现在总共有 10 条数据

每个页面最多显示 3页数据
每页最多显示2条数据..

保存在数据库中的数据一共 10 条
一次从数据库中读取3页数据 = 3 X 2 = 6 条
每页显示2条: 对6条数据进行分页, 每次显示有3页...


之前给楼主说的看google对搜索结果的处理,, 貌似楼主压根就没看.....

1.在分页的时候首先需要知道数据库中总共有多少条记录, 例如例子中 总共有 10 条
2.需要知道每个页面显示多少条数据, 例如例子中 总共有 2 条
3.一次给用户展示多少页: 例如例子中 总共有 3 页

那么这个流程就很清晰了....

晕死, 下班了. 楼主先自己想着... 要是还想不明白 回头再议..




文章评论

初级 vs 高级开发者 哪个性价比更高?
初级 vs 高级开发者 哪个性价比更高?
程序员的一天:一寸光阴一寸金
程序员的一天:一寸光阴一寸金
程序猿的崛起——Growth Hacker
程序猿的崛起——Growth Hacker
旅行,写作,编程
旅行,写作,编程
如何成为一名黑客
如何成为一名黑客
我是如何打败拖延症的
我是如何打败拖延症的
“肮脏的”IT工作排行榜
“肮脏的”IT工作排行榜
程序员眼里IE浏览器是什么样的
程序员眼里IE浏览器是什么样的
做程序猿的老婆应该注意的一些事情
做程序猿的老婆应该注意的一些事情
程序员最害怕的5件事 你中招了吗?
程序员最害怕的5件事 你中招了吗?
漫画:程序员的工作
漫画:程序员的工作
写给自己也写给你 自己到底该何去何从
写给自己也写给你 自己到底该何去何从
如何区分一个程序员是“老手“还是“新手“?
如何区分一个程序员是“老手“还是“新手“?
我的丈夫是个程序员
我的丈夫是个程序员
2013年美国开发者薪资调查报告
2013年美国开发者薪资调查报告
Java 与 .NET 的平台发展之争
Java 与 .NET 的平台发展之争
每天工作4小时的程序员
每天工作4小时的程序员
程序员都该阅读的书
程序员都该阅读的书
总结2014中国互联网十大段子
总结2014中国互联网十大段子
什么才是优秀的用户界面设计
什么才是优秀的用户界面设计
2013年中国软件开发者薪资调查报告
2013年中国软件开发者薪资调查报告
编程语言是女人
编程语言是女人
鲜为人知的编程真相
鲜为人知的编程真相
团队中“技术大拿”并非越多越好
团队中“技术大拿”并非越多越好
老程序员的下场
老程序员的下场
科技史上最臭名昭著的13大罪犯
科技史上最臭名昭著的13大罪犯
当下全球最炙手可热的八位少年创业者
当下全球最炙手可热的八位少年创业者
看13位CEO、创始人和高管如何提高工作效率
看13位CEO、创始人和高管如何提高工作效率
那些争议最大的编程观点
那些争议最大的编程观点
为什么程序员都是夜猫子
为什么程序员都是夜猫子
老美怎么看待阿里赴美上市
老美怎么看待阿里赴美上市
“懒”出效率是程序员的美德
“懒”出效率是程序员的美德
5款最佳正则表达式编辑调试器
5款最佳正则表达式编辑调试器
 程序员的样子
程序员的样子
程序员必看的十大电影
程序员必看的十大电影
Web开发人员为什么越来越懒了?
Web开发人员为什么越来越懒了?
程序员周末都喜欢做什么?
程序员周末都喜欢做什么?
不懂技术不要对懂技术的人说这很容易实现
不懂技术不要对懂技术的人说这很容易实现
一个程序员的时间管理
一个程序员的时间管理
程序员和编码员之间的区别
程序员和编码员之间的区别
十大编程算法助程序员走上高手之路
十大编程算法助程序员走上高手之路
为啥Android手机总会越用越慢?
为啥Android手机总会越用越慢?
Web开发者需具备的8个好习惯
Web开发者需具备的8个好习惯
聊聊HTTPS和SSL/TLS协议
聊聊HTTPS和SSL/TLS协议
10个调试和排错的小建议
10个调试和排错的小建议
60个开发者不容错过的免费资源库
60个开发者不容错过的免费资源库
那些性感的让人尖叫的程序员
那些性感的让人尖叫的程序员
Java程序员必看电影
Java程序员必看电影
亲爱的项目经理,我恨你
亲爱的项目经理,我恨你
软件开发程序错误异常ExceptionCopyright © 2009-2015 MyException 版权所有