jsp分页技术实现Word下载.docx
《jsp分页技术实现Word下载.docx》由会员分享,可在线阅读,更多相关《jsp分页技术实现Word下载.docx(32页珍藏版)》请在冰豆网上搜索。
因此需要一些工具类简化分页代码,使程序员专注于业务逻辑部分。
下面是我设计的两个工具类:
PagedStatement
封装了数据库连接、总记录数查询、分页查询、结果数据封装和关闭数据库连接等操作,并使用了PreparedStatement支持动态设置参数。
RowSetPage
参考PetStore的page
page
iterator模式,
设计RowSetPage用于封装查询结果(使用OracleCachedRowSet缓存查询出的一页数据,关于使用CachedRowSet封装数据库查询结果请参考JSP页面查询显示常用模式)以及当前页码、总记录条数、当前记录数等信息,
并且可以生成简单的HTML分页代码。
查询的结果封装成RowsetPage。
下面是简单的使用示例:
1.
2.
//DAO查询数据部分代码:
3.
…
4.
public
RowSetPage
getEmployee(String
gender,
int
pageNo)
throws
Exception{
5.
String
sql="
emp_id,
emp_code,
user_name,
real_name
gender
=?
"
;
6.
//使用Oracle数据库的分页查询实现,每页显示5条
7.
PagedStatement
pst
=new
PagedStatementOracleImpl(sql,
pageNo,
5);
8.
pst.setString(1,
gender);
9.
return
pst.executeQuery();
10.
}
11.
12.
13.
//Servlet处理查询请求部分代码:
14.
15.
16.
pageNo;
17.
try{
18.
//可以通过参数pageno获得用户选择的页码
19.
pageNo
=
Integer.parseInt(request.getParameter("
pageno"
);
20.
}catch(Exception
ex){
21.
//默认为第一页
22.
pageNo=1;
23.
24.
request.getParameter("
gender"
25.
request.setAttribute("
empPage"
myBean.getEmployee(gender,
26.
27.
28.
//JSP显示部分代码
29.<
%@
import
page.RowSetPage"
%>
30.
31.
script
language="
javascript"
>
32.
function
doQuery(){
33.
form1.actionType.value="
doQuery"
34.
form1.submit();
35.
36.
/script>
37.
38.
form
name=form1
method=get>
39.
input
type=hidden
name=actionType>
40.
性别:
41.
type=text
name=gender
size=1
value="
%=request.getParameter("
)%>
42.
type=button
查询
onclick="
doQuery()"
43.<
%
44.
empPage
(RowSetPage)request.getAttribute("
45.
if
(empPage
==
null
RowSetPage.EMPTY_PAGE;
46.%>
47.
48.
table
cellspacing="
0"
width="
90%"
49.
tr>
td>
ID<
/td>
代码<
用户名<
姓名<
/tr>
50.<
51.
javax.sql.RowSet
empRS
(javax.sql.RowSet)
empPage.getRowSet();
52.
(empRS!
=null)
while
(empRS.next()
{
53.%>
54.
55.
%=
empRS.getString("
EMP_ID"
56.
EMP_CODE"
57.
USER_NAME"
58.
REAL_NAME"
59.
60.<
61.
}//
end
while
62.%>
63.
64.<
65.
//显示总页数和当前页数(pageno)以及分页代码。
66.
//此处doQuery为页面上提交查询动作的javascript函数名,
pageno为标识当前页码的参数名
67.%>
68.
td
colspan=4>
.getHTML("
69.
70.
/table>
71.
/form>
效果如图:
因为分页显示一般都会伴有查询条件和查询动作,页面应已经有校验查询条件和提交查询的javascript方法(如上面的doQuery),所以RowSetPage.getHTML()生成的分页代码在用户选择新页码时直接回调前面的处理提交查询的javascript方法。
注意在显示查询结果的时候上次的查询条件也需要保持,如<
。
同时由于页码的参数名可以指定,因此也支持在同一页面中有多个分页区。
另一种分页代码实现是生成每一页的URL,将查询参数和页码作为QueryString附在URL后面。
这种方法的缺陷是在查询条件比较复杂时难以处理,并且需要指定处理查询动作的servlet,可能不适合某些定制的查询操作。
如果对RowSetPage.getHTML()生成的默认分页代码不满意可以编写自己的分页处理代码,RowSetPage提供了很多getter方法用于获取相关信息(如当前页码、总页数、
总记录数和当前记录数等)。
在实际应用中可以将分页查询和显示做成jsp
taglib,
进一步简化JSP代码,屏蔽Java
Code。
附:
分页工具类的源代码,
有注释,应该很容易理解。
1.Page.java
2.RowSetPage.java(RowSetPage继承Page)
3.PagedStatement.java
4.PagedStatementOracleImpl.java(PagedStatementOracleImpl继承PagedStatement)
您可以任意使用这些源代码,但必须保留author
evan_zhao@字样
2.///////////////////////////////////
3.//
4.//
Page.java
5.//
evan_zhao@
6.//
7.///////////////////////////////////
8.
9.package
page;
10.
11.import
java.util.List;
12.import
java.util.ArrayList;
13.import
java.util.Collection;
14.import
java.util.Collections;
15.
16.
17./**
Title:
分页对象<
br>
Description:
用于包含数据及分页信息的对象<
Page类实现了用于显示分页信息的基本方法,但未指定所含数据的类型,
可根据需要实现以特定方式组织数据的子类,<
如RowSetPage以RowSet封装数据,ListPage以List封装数据<
Copyright:
Copyright
(c)
2002
@author
evan_zhao@
@version
1.0
*/
27.public
class
Page
implements
java.io.Serializable
static
final
EMPTY_PAGE
new
Page();
29.
DEFAULT_PAGE_SIZE
20;
MAX_PAGE_SIZE
9999;
31.
private
myPageSize
DEFAULT_PAGE_SIZE;
33.
start;
avaCount,totalSize;
Object
data;
37.
currentPageno;
totalPageCount;
40.
/**
默认构造方法,只构造空页
43.
protected
Page(){
this.init(0,0,0,DEFAULT_PAGE_SIZE,new
Object());
46.
47.
分页数据初始方法,由子类调用
50.
@param
start
本页数据在数据库中的起始位置
avaCount
本页包含的数据条数
totalSize
数据库中总记录条数
53.
pageSize
本页容量
data
本页包含的数据
void
init(int
start,
avaCount,
totalSize,
pageSize,
data){
57.
this.avaCount
=avaCount;
this.myPageSize
pageSize;
60.
this.start
62.
this.totalSize
totalSize;
63.
64.
this.data=data;
65.
//System.out.println("
avaCount:
+avaCount);
67.
totalSize:
+totalSize);
(avaCount>
totalSize)
//throw
RuntimeException("
记录条数大于总条数?
!
71.
72.
this.currentPageno
(start
-1)/pageSize
+1;
73.
this.totalPageCount
(totalSize
+
-1)
/
74.
75.
(totalSize==0
&
avaCount==0){
76.
1;
77.
78.
79.
Start
Index
to
No:
-"
currentPageno);
80.
81.
82.
getData(){
83.
this.data;
84.
85.
86.
87.
取本页数据容量(本页能包含的记录数)
88.
@return
本页能包含的记录数
89.
90.
getPageSize(){
91.
this.myPageSize;
92.
93.
94.
95.
是否有下一页
96.
97.
98.
boolean
hasNextPage()
99.
/*
100.
(avaCount==0
totalSize==0){
101.
false;
102.
103.
104.
105.
(this.getCurrentPageNo()<
this.getTotalPageCount());
106.
107.
108.
109.
是否有上一页
110.
111.
112.
hasPreviousPage()
113.
114.
115.
116.
(this.getCurrentPageNo()>
1);
117.
118.
119.
120.
获取当前页第一条数据在数据库中的位置
121.
@return
122.
123.
getStart(){
124.
125.
126.
127.
128.
获取当前页最后一条数据在数据库中的位置
129.
130.
131.
getEnd(){
132.
this.getStart()
this.getSize()
-1;
133.
(end<
0)
134.
0;
135.
136.
end;
137.
138.
139.
140.
获取上一页第一条数据在数据库中的位置
141.
记录对应的rownum
142.
143.
getStartOfPreviousPage()
144.
Math.max(start-myPageSize,
145.
146.
147.
148.
149.
获取下一页第一条数据在数据库中的位置
150.
151.
152.
getStartOfNextPage()
153.
avaCount;
154.
155.
156.
157.
获取任一页第一条数据在数据库中的位置,每页条数使用默认值
158.
页号
159.
160.
161.
getStartOfAnyPage(int
pageNo){
162.
getStartOfAnyPage(pageNo,
DEFAULT_PAGE_SIZE);
163.
164.
165.
166.
获取任一页第一条数据在数据库中的位置
167.
168.
每页包含的记录数
169.
170.
171.
pageSize){
172.
startIndex
(pageNo-1)
173.