Chinaunix首页 | 论坛 | 博客
  • 博客访问: 30462454
  • 博文数量: 708
  • 博客积分: 12163
  • 博客等级: 上将
  • 技术积分: 8240
  • 用 户 组: 普通用户
  • 注册时间: 2007-12-04 20:59
文章分类

全部博文(708)

分类: Java

2008-03-17 11:36:35

一个通用的分页方法,不仅在数据库操作上分页了还在上层也做了分页.理解了这个就很容易理解其他框架的分页了.

java 代码

1.
2. import java.math. * ;
3.
4.
5.
6. public class Pager {
7.
8. private int totalRows; // 总行数

9.
10. private int pageSize=30 ; // 每页显示的行数

11.
12. private int currentPage; // 当前页号

13.
14. private int totalPages; // 总页数

15.
16. private int startRow; // 当前页在数据库中的起始行

17.
18.
19.
20. public Pager() {
21.
22.
23.
24. }
25.
26.
27.
28. public Pager( int _totalRows) {
29.
30. totalRows=_totalRows;
31.
32. totalPages=totalRows / pageSize;
33.
34. int mod=totalRows % pageSize;
35.
36. if (mod > 0 ) {
37.
38. totalPages ++ ;
39.
40. }
41.
42. currentPage=1 ;
43.
44. startRow=0 ;
45.
46. }
47.
48.
49.
50. public int getStartRow() {
51.
52. return startRow;
53.
54. }
55.
56. public int getTotalPages() {
57.
58. return totalPages;
59.
60. }
61.
62. public int getCurrentPage() {
63.
64. return currentPage;
65.
66. }
67.
68. public int getPageSize() {
69.
70. return pageSize;
71.
72. }
73.
74. public void setTotalRows( int totalRows) {
75.
76. this.totalRows = totalRows;
77.
78. }
79.
80. public void setStartRow( int startRow) {
81.
82. this.startRow = startRow;
83.
84. }
85.
86. public void setTotalPages( int totalPages) {
87.
88. this.totalPages = totalPages;
89.
90. }
91.
92. public void setCurrentPage( int currentPage) {
93.
94. this.currentPage = currentPage;
95.
96. }
97.
98. public void setPageSize( int pageSize) {
99.
100. this.pageSize = pageSize;
101.
102. }
103.
104. public int getTotalRows() {
105.
106. return totalRows;
107.
108. }
109.
110. public void first() {
111.
112. currentPage = 1 ;
113.
114. startRow = 0 ;
115.
116. }
117.
118. public void previous() {
119.
120. if (currentPage == 1 ) {
121.
122. return ;
123.
124. }
125.
126. currentPage -- ;
127.
128. startRow =(currentPage-1)*pageSize;
129.
130. }
131.
132. public void next() {
133.
134. if (currentPage<totalPages) {
135.
136. currentPage ++ ;
137.
138. }
139.
140. startRow=(currentPage-1)*pageSize;
141.
142. }
143.
144. public void last() {
145.
146. currentPage=totalPages;
147.
148. startRow=(currentPage-1 )*pageSize;
149.
150. }
151.
152. public void refresh(int _currentPage) {
153.
154. currentPage=_currentPage;
155.
156. if (currentPage>totalPages) {
157.
158. last();
159.
160. }
161.
162. }
163.
164. }
165.
166.
167.

操作pager的PagerService

java 代码

 

1.
2. package com.game.common;
3.
4.
5.
6. public class PagerService {
7.
8.
9.
10.
11.
12.
13.
14. public Pager getPager(String currentPage,String pagerMethod, int totalRows) {
15.
16. // 定义pager对象,用于传到页面
17.
18. Pager pager= new Pager(totalRows);
19.
20. // 如果当前页号为空,表示为首次查询该页
21.
22. // 如果不为空,则刷新pager对象,输入当前页号等信息
23.
24. if (currentPage!=null ) {
25.
26. pager.refresh(Integer.parseInt(currentPage));
27.
28. }
29.
30. // 获取当前执行的方法,首页,前一页,后一页,尾页。
31.
32. if (pagerMethod!=null ) {
33.
34. if (pagerMethod.equals("first")) {
35.
36. pager.first();
37.
38. } else if (pagerMethod.equals("previous")) {
39.
40. pager.previous();
41.
42. } else if (pagerMethod.equals("next")) {
43.
44. pager.next();
45.
46. } else if (pagerMethod.equals("last")) {
47.
48. pager.last();
49.
50. }
51.
52. }
53.
54. return pager;
55.
56. }
57.
58. }
59.
60.
61.

java 代码

 

1.
2. public class ProductsDaoImp extends HibernateDaoSupport implements ProductsDao {
3.
4.
5.
6. public int getRows() {
7.
8.
9.
10. String sql = " FROM Products ORDER BY gameNameCn " ;
11.
12. List list = this .getHibernateTemplate().find(sql);
13.
14. return list.size();
15.
16.
17.
18. }
19.
20.
21.
22. public void addProduct(Products pd) {
23.
24. this.getHibernateTemplate().save(pd);
25.
26.
27.
28. }
29.
30.
31.
32. public void deleteProduct(Products pd) {
33.
34. this.getHibernateTemplate().delete(pd);
35.
36.
37.
38. }
39.
40.
41.
42. public String getMaxId() {
43.
44. String sql="select max(gameId)+1 from Products" ;
45.
46. String noStr=null;
47.
48. List list=(List)this.getHibernateTemplate().find(sql);
49.
50. Iterator it=list.iterator();
51.
52. if(it.hasNext()){
53.
54. Object noInt=it.next();
55.
56. if(noInt==null){
57.
58. noStr="1";
59.
60. }else{
61.
62. noStr=noInt.toString();
63.
64. }
65.
66.
67.
68. }
69.
70. if(noStr.length()==1){
71.
72. noStr="000"+noStr;
73.
74. }else if(noStr.length()==2){
75.
76. noStr="00"+noStr;
77.
78. }else if(noStr.length()==2){
79.
80. noStr="0"+noStr;
81.
82. } else {
83.
84. noStr=noStr;
85.
86. }
87.
88.
89.
90. return noStr;
91.
92. }
93.
94.
95.
96. public List getProducts() {
97.
98. String hql="from products order by gameNameCn" ;
99.
100. this.getHibernateTemplate().find(hql);
101.
102. return null;
103.
104. }
105.
106.
107.
108. public List getProducts(final int pageSize, final int startRow) {
109.
110.
111.
112. return this.getHibernateTemplate().executeFind(new HibernateCallback(){
113.
114.
115.
116. public Object doInHibernate(Session session ) throws HibernateException, SQLException {
117.
118. Query query=session.createQuery("from products order by gameNameCn" );
119.
120. query.setFirstResult(startRow);
121.
122.
123.
124. query.setMaxResults(pageSize);
125.
126. return query.list();
127.
128. }
129.
130.
131.
132. });
133.
134.
135.
136. }
137.
138.
139.
140. public Products getProducts(int gameId) {
141.
142. return (Products)this.getHibernateTemplate().get(Products.class, gameId);
143.
144.
145.
146. }
147.
148.
149.
150. public int getRows(String fieldName, String value) {
151.
152.
153.
154. String sql = " FROM Products where " + fieldName + " like '% " + value + " %' " + " ORDER BY gameNameCn " ;
155.
156. List list = this .getHibernateTemplate().find(sql);
157.
158. return list.size();
159.
160. }
161.
162.
163.
164. public List queryProducts(String fieldName, String value) {
165.
166. String sql = "FROM Products where" + fieldName + "like'%" + value + "%' " + "ORDER BY gameNameCn" ;
167.
168.
169.
170. return this.getHibernateTemplate().find(sql);
171.
172. }
173.
174.
175.
176. public List queryProducts(String fieldName, String value, final int pageSize,
177.
178. final int startRow) {
179.
180. final String sql = " FROM Products where " + fieldName+ " like '% " + value + " %' " + " ORDER BY gameNameCn " ;
181.
182. return this.getHibernateTemplate().executeFind(new HibernateCallback(){
183.
184.
185.
186.
187.
188. public Object doInHibernate(Session session ) throws HibernateException, SQLException {
189.
190. Query query=session.createQuery(sql);
191.
192. query.setFirstResult(startRow);
193.
194.
195.
196. query.setMaxResults(pageSize);
197.
198. return query.list();
199.
200. }
201.
202.
203.
204. });
205.
206.
207.
208.
209.
210. }
211.
212.
213.
214. public void updateProductd(Products pd) {
215.
216. this.getHibernateTemplate().update(pd);
217.
218. }
219.
220.
221.
222. }

阅读(2188) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~