Jsp真分页实例---分页
网页的分页功能的实现比较简单,实现方法也多种多样。
今天总结一个简单的Jsp真分页实例。
首先,提到分页就要先明确一个概念,何为真分页何谓假分页。
假分页:一次性从数据库读出表的所有数据一次性的返回给客户端,由js来控制每一页的显示。
真分页:由程序控制,每一次只返回一页大小的数据,显示到客户端。
由此可以很清楚的分辨出真假分页各自的优缺点:
假分页:由于一次性读出所有数据并返回给客户端,如果数据量庞大,所以这一次的动作可能是非常消耗服务器资源和带宽的,
但是返回给客户端以后就非常轻松了,客户在一段时间内不会再像服务器端请求资源。但不代表可能出现一些意外情况,
比如说客户将浏览器关闭,重新访问网站等。所以,如果数据量相当庞大,不建议使用用真分页。
真分页:假分页每次只取需要的数据返回给客户端,比起真分页没有那么大的数据库压力。但也因为这个工作特性,所以假分页
的方法需要频繁和服务器端进行交互。既然频繁交互,自然也会给服务器带来负担。
综上:如果数据量较小,使用假分页的效果会更优,如果数据量庞大,使用真分页的效果更优。
分析完特性,下面就来列举一个简单的真分页实例。
真分页是通过程序来控制的,每次向数据库请求需要的数据。
简述实现思路业务流程:
首先:客户端带着page参数请求客户端,若没有带page参数,说明是第一次访问,则page参数默认为0;
其次:服务端根据page参数,调用相关函数,从数据库中取出表中数据,封装成相关对象,返回给客户端,并且返回新page参数及总页数;
最后:再客户端显示请求的相关数据,并根据page参数及总页数两个参数,决定上一页下一页的按钮是否可用。
数据库操作类:
publicclassDBBean{
privateConnectioncon;
privatePreparedStatementpstmt;
privateResultSetrs;
privateStringdbName="test";
privateStringdbuser="root";
privateStringdbpass="******";
static{
try{
Class.forName("com.mysql.jdbc.Driver");
}catch(ClassNotFoundExceptione){
System.out.println(e);
}
}
publicvoidprepareConnection(){
try{
con=DriverManager.getConnection("jdbc:mysql://localhost:3306/"+dbName,dbuser,dbpass);
}catch(SQLExceptione){
System.out.println(e);
}
}
//关闭连接
publicvoidclose(){
try{
if(con!=null)
con.close();
}catch(SQLExceptione){
//TODOAuto-generatedcatchblock
e.printStackTrace();
}
con=null;
try{
if(pstmt!=null)
pstmt.close();
}catch(SQLExceptione){
//TODOAuto-generatedcatchblock
e.printStackTrace();
}
pstmt=null;
}
//设置参数
privatevoidsetParems(String[]parems){
if(parems!=null){
for(inti=0;i
学生类:
publicclassStudentBean{
privatelongid;
privateStringname;
privateStringphone;
privateintage;
privateintscore;
publiclonggetId(){
returnid;
}
publicvoidsetId(longid){
this.id=id;
}
publicStringgetName(){
returnname;
}
publicvoidsetName(Stringname){
this.name=name;
}
publicStringgetPhone(){
returnphone;
}
publicvoidsetPhone(Stringphone){
this.phone=phone;
}
publicintgetAge(){
returnage;
}
publicvoidsetAge(intage){
this.age=age;
}
publicintgetScore(){
returnscore;
}
publicvoidsetScore(intscore){
this.score=score;
}
}
学生数据操作类
publicclassStudentDaoimplementsStudentDaoIn{
@Override
publicArrayListfindByPage(intpage){
DBBeandb=newDBBean();
intbegin=(page-1)*5;
Stringsql="select*fromt_studentlimit"+begin+",5";
ResultSetrs=db.executeQuery(sql,null);
ArrayListlist=newArrayList();
try{
while(rs.next()){
StudentBeanst=newStudentBean();
st.setName(rs.getString("name"));
st.setAge(rs.getInt("age"));
st.setId(rs.getInt("id"));
st.setPhone(rs.getString("phnoe"));
st.setScore(rs.getInt("score"));
list.add(st);
}
}catch(SQLExceptione){
//TODOAuto-generatedcatchblock
e.printStackTrace();
}
returnlist;
}
@Override
publicintuserCount(){
DBBeandb=newDBBean();
Stringsql="selectcount(*)fromt_student";
ResultSetrs=db.executeQuery(sql,null);
intcount=0;
try{
rs.next();
count=rs.getInt(1);
}catch(SQLExceptione){
//TODOAuto-generatedcatchblock
e.printStackTrace();
}
returncount;
}
}
相关业务逻辑
protectedvoiddoGet(HttpServletRequestrequest,HttpServletResponseresponse)throwsServletException,IOException{
//TODOAuto-generatedmethodstub
Stringpage=null;
page=request.getParameter("page");
if(page==null||page=="")
page="1";
StudentDaostudao=newStudentDao();
request.setAttribute("student",studao.findByPage(Integer.parseInt(page)));
request.setAttribute("pagenum",studao.userCount()/5+1);//总页数
request.setAttribute("page",page);//当前页
request.getRequestDispatcher("student.jsp").forward(request,response);
}
前台JSP代码:
ID
姓名
年龄
电话
成绩
${st.getId()}
${st.getName()}
${st.getAge()}
${st.getPhone()}
${st.getScore()}
共${pagenum}页当前第${page}页
1}">
本例是真分页的一个简单实现,有着明显的缺点。
例如:
1.在后台相关业务逻辑处,只对page做了简单的判断,因为查询相关page时,参数是写入前台a标签中的,所以懂技术的用户,可以随意改动其值
由此查询数据库可能带来意想不到的错误。
2.功能不够完善,仅提供了上一页下一页按钮的简单功能。
另外:实现假分页时可以结合ajax和json。以此可实现无刷新翻页,看起来功能和真分页一样。。。