hibernate mysql分页_java 实现分页技术(Structs+Hibernate+MySQL)

通过Structs+Hibernate+MySQL数据数来实现分页技术的应用.

源程序下载

至于Hibernate, Structs, MySQL的具体用法我就不说了,你可以看源程序来查看详细内容.我们来看看分页应用的相关内容.

架构上和Spring JPetStore没多少区别, 只是没用Spring框架所以Structs中的UserdisplayAction中必须new出各个对象并完成它们之间的关联, 这就是Spring IOC可自动完成的功能. 它也是三层:表现层(Structs), 业务层(POJO), 数据层(Hibernate访问MySQL). 同样业务层通过DAO接口(UserDAO)来访问数据库, 访问数据库的通过Hibernate(在UserDAOImpl中实现). 这一次分页要在业务层中来实现, 业务层同样向表现层提供一个Facada(门面, UserManager接口), 来访问业务. 在UserManagerImpl中通过调用UserDAO来访问数据, 调用POJO来实现分页功能. 看以下关键代码.

先看POJO的分布类吧:

Page.java

package org.flyware.util.page;

public class Page {

private boolean hasPrePage;

private boolean hasNextPage;

private int everyPage;

private int totalPage;

private int currentPage;

private int beginIndex;

public Page(){

}

public Page(int everyPage){

this.everyPage = everyPage;

}

/** The whole constructor */

public Page(boolean hasPrePage, boolean hasNextPage,

int everyPage, int totalPage,

int currentPage, int beginIndex) {

this.hasPrePage = hasPrePage;

this.hasNextPage = hasNextPage;

this.everyPage = everyPage;

this.totalPage = totalPage;

this.currentPage = currentPage;

this.beginIndex = beginIndex;

}

......

public int getTotalPage() {

return totalPage;

}

public void setTotalPage(int totalPage) {

this.totalPage = totalPage;

}

}

PageUtil.java(用来构造Page实例 相当于page工厂)

package org.flyware.util.page;

public class PageUtil {

private static final Log logger = LogFactory.getLog(PageUtil.class);

public static Page createPage(Page page, int totalRecords){

return createPage(page.getEveryPage(), page.getCurrentPage(), totalRecords);

}

public static Page createPage(int everyPage, int currentPage, int totalRecords){

everyPage = getEveryPage(everyPage);

currentPage = getCurrentPage(currentPage);

int beginIndex = getBeginIndex(everyPage, currentPage);

int totalPage = getTotalPage(everyPage, totalRecords);

boolean hasNextPage = hasNextPage(currentPage, totalPage);

boolean hasPrePage = hasPrePage(currentPage);

return new Page(hasPrePage, hasNextPage,

everyPage, tot

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值