比如你有个List list = new ArrayList();你在页面拿到这个list集合,存在页面内存里面,通过数组下边每次取5条记录,来实现分页效果怎么不直在后台用分页查询其实分页的道理很简单,比如100一页,设定一个自增变量从0开始,第一页的100个就是0*100--到--0*100+100。第二页是(0+1)*100--到--(0+1)*100+100,第三页就继续+1这么做 只能说你的设计有问题把list放在session里,然后计算出页码,利用页码和每页显示的数据量,控制要显示的数据,显示在页面上。
处理方式:一:首先sql语句,使用not in的方式处理,在dao类里写一个方法public List<> getAllByPage(int pageSize,pageNum)......String sql="select top"+pageSize +" * from 表名x where 字段A not in (select top "+pageSize*(pageNum-1)+" 字段A from 表名x)";.......rerun list;}其中,pageSize是页面要显示的条数,pageNum是要显示的页码,sql语句是固定的,返回一个list对象。二:在Biz里写一个方法,调用Dao里的getAllByPage方法,传入两个参数,返回list结果集。三:在jsp页面以url传参的方式进行页面处理和数据的显示。使用request对象获取传入的值,进行强制类型转作为参数,传入到Biz业务类的方法中处理,返回list结果集,使用表达式的方式在页面中进行显示。分页显示一般有两种实现方式:业务层分页、数据库层分页(以下会用到两个参数,提前说明下 page:请求第几页,size:每页显示多少条) 业务层分页:从数据库取出所有数据,然后通过传过来的page和size对所有数据截取,比如一共查了100条数据,保存在list里面,要求查询第2页,每页显示10条,则可以通过list属性,取100条数据 中的第11条到第20条,可通过遍历实现。 数据库层分页:数据库都会有分页函数(mysql 是limit函数,sqlserver是row_number()函数,可自行百度下)该方法是通过传过来的page和size在查询数据库时就开始分页,以mysql为例,查询第2页,每页显示10条,则sql语句是 ”select * from xx limit 10,10“(第一个10表示从下标为10开始查,第二个10是共读取10条) 性能肯定是第二种分页方式好,只要搞懂分页原理,想实现分页其实很简单,只要搞清楚分页是将多条数据中的某几条挑出来
网站栏目:如何对list进行分页,怎么实现listview分页
文章网址:http://csdahua.cn/article/icices.html