操作数据: PageDao.java
package com.enorth.lichen.youth.dao;
import java.util.ArrayList;
import java.util.List;
import org.hibernate.Session;
import com.enorth.lichen.youth.hi.HibernateUtils;
public class PageDao {
public List pageQuery(int pageSize, int pageNow){
List list=new ArrayList();
Session session = null;
try {
session = HibernateUtils.getSession();
session.beginTransaction();
//得到每页显示的LevTwoInFuUser的对象的集合list
list = session.createQuery("from LevTwoInFuUser l2if where l2if.permission = 201 order by l2if.l2infid")
.setFirstResult(pageNow*pageSize-pageSize)
.setMaxResults(pageSize)
.list();
session.getTransaction().commit();
}catch(Exception e) {
e.printStackTrace();
session.getTransaction().rollback();
}finally {
HibernateUtils.closeSession(session);
}
return list;
}
public int pageTotle(int pageSize, int pageNow){
int i=0;
Session session = null;
try {
session = HibernateUtils.getSession();
session.beginTransaction();
//i是查询结果条数
i = session.createQuery("from LevTwoInFuUser l2if where l2if.permission = 201 order by l2if.l2infid")
.list()
.size();
//用总的结果条数对每页显示的条数取余,得到总页数
i=i%pageSize==0?i/pageSize:i/pageSize+1 ;
session.getTransaction().commit();
}catch(Exception e) {
e.printStackTrace();
session.getTransaction().rollback();
}finally {
HibernateUtils.closeSession(session);
}
return i;
}
}
Action处理: PageQueryAction.java
package com.enorth.lichen.youth.act;
import java.util.List;
import java.util.Map;
import javax.servlet.http.HttpServletRequest;
import org.apache.struts2.interceptor.ServletRequestAware;
import org.apache.struts2.interceptor.SessionAware;
import com.enorth.lichen.youth.dao.PageDao;
import com.opensymphony.xwork2.ActionSupport;
public class PageQueryAction extends ActionSupport implements ServletRequestAware,SessionAware{
private HttpServletRequest request;
private List list;
private int pageNow = 1 ; //初始化为1,默认从第一页开始显示
private int pageSize = 3 ; //每页显示3条记录
private int pageTotle= 1 ;//总页数
private PageDao pageDao = new PageDao () ;
public List getList() {
return list;
}
public void setList(List list) {
this.list = list;
}
public int getPageNow() {
return pageNow;
}
public void setPageNow(int pageNow) {
this.pageNow = pageNow;
}
public int getPageSize() {
return pageSize;
}
public void setPageSize(int pageSize) {
this.pageSize = pageSize;
}
public int getPageTotle() {
return pageTotle;
}
public void setPageTotle(int pageTotle) {
this.pageTotle = pageTotle;
}
@Override
public String execute() throws Exception {
//得到每页显示的对象的集合list
list = pageDao.pageQuery(pageSize, pageNow);
//得到总页数pageTotle
pageTotle=pageDao.pageTotle(pageSize, pageNow);
return SUCCESS;
}
@Override
public void setServletRequest(HttpServletRequest request) {
// TODO Auto-generated method stub
this.request=request;
}
@Override
public void setSession(Map arg0) {
// TODO Auto-generated method stub
}
}
查询分页页面: page.jsp
<%@ page language="java" import="java.util.*" pageEncoding="gbk"%>
<%
String path = request.getContextPath();
String basePath = request.getScheme() + "://"
+ request.getServerName() + ":" + request.getServerPort()
+ path + "/";
%>
<%@taglib prefix="s" uri="/struts-tags"%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<SCRIPT type="text/javascript" src="js/calendar.js"></SCRIPT>
<base href="<%=basePath%>">
<title>分页</title>
<meta http-equiv="pragma" content="no-cache">
<meta http-equiv="cache-control" content="no-cache">
<meta http-equiv="expires" content="0">
<meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
<meta http-equiv="description" content="This is my page">
<!--
<link rel="stylesheet" type="text/css" href="styles.css">
-->
</head>
<body>
<table border="1">
<tr>
<th>
用户编号
</th>
<th>
真实姓名
</th>
<th>
注册时间
</th>
</tr>
<!-- 迭代查询 -->
<s:iterator value="list">
<tr>
<td>
<s:property value="l2infid" />
</td>
<td>
<s:property value="realname" />
</td>
<td>
<s:property value="registime" />
</td>
</tr>
</s:iterator>
</table>
<!-- 首页 -->
<s:url id="url_first" value="page.action">
<s:param name="pageNow" value="1"></s:param>
</s:url>
<!-- 上一页 -->
<s:url id="url_pre" value="page.action">
<s:param name="pageNow" value="pageNow-1"></s:param>
</s:url>
<!-- 下一页 -->
<s:url id="url_next" value="page.action">
<s:param name="pageNow" value="pageNow+1"></s:param>
</s:url>
<!-- 末页 -->
<s:url id="url_last" value="page.action">
<s:param name="pageNow" value="pageTotle"></s:param>
</s:url>
<!-- 如果不是首页则提供首页的链接,如果是首页则不提供链接,以下类似 -->
<s:if test="pageNow != 1">
[<s:a href="%{url_first}">首页</s:a>]
</s:if>
<s:else>
[首页]
</s:else>
<s:if test="pageNow>1">
[<s:a href="%{url_pre}">上一页</s:a>]
</s:if>
<s:else>
[上一页]
</s:else>
<!-- for循环, current是循环变量(org.apache.struts2.util.Counter里定义的)-->
<s:bean name="org.apache.struts2.util.Counter" id="i">
<s:param name="first" value="1" />
<s:param name="last" value="%{pageTotle}" />
<s:iterator>
<s:if test="pageNow+1== current">
<font color="#3f84ff"><b><s:property /></b></font>
</s:if>
<s:else>
<s:a href="page.action?pageNow=%{current-1}"> <font color="#2fa2ff"><s:property /></font></s:a>
</s:else>
</s:iterator>
</s:bean>
<s:iterator value="list" status="status">
<s:url id="url" value="page.action">
<s:param name="pageNow" value="pageNow" />
<s:param name="pageTotle" value="pageTotle" />
</s:url>
</s:iterator>
<s:if test=" pageTotle > pageNow ">
[<s:a href="%{url_next}">下一页</s:a>]
</s:if>
<s:else>
[下一页]
</s:else>
<s:if test="pageTotle != pageNow">
[<s:a href="%{url_last}">末页</s:a>]
</s:if>
<s:else>
[末页]
</s:else>
</body>
</html>
本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/lc19850921/archive/2009/01/07/3727388.aspx
分享到:
相关推荐
Struts2+Spring2.0+Hibernate3.2.0(API)
Struts2.3 + Spring3.2 + Hibernate4.1 + HTML5 + CSS3开发示例代码。 其中包括如下文件: 介绍文档 Struts2.3 + Spring3.2 + Hibernate4.1 + HTML5 + CSS3开发示例.docx Eclipse工程文件 SSH2.zip Zip包是Eclipse...
struts2.2.3+spring2.5+hibernate3.2事务 有所用到的JAR
struts2.1 + hibernate3.2+spring2.5整合 给大家散发个S2SH整合视频,希望对大家有所帮助
struts2+spring2.0+hibernate3.2+Security2.0的demo程序 里面带有 mysql的 DBdump, 可以直接导入DB S2SH的整合使用注解的方式 里面包括全部的jar包
该项目用的是struts-2.3.15,hibernate-release-4.2.3.Final,spring-framework-3.2.3 来进行整合的!希望对大家有帮助,特别是刚接触hibernate4的~带有sql文件,方便创建例子用到的数据库。
对于初学者很有帮助的文档和例子,希望大家能从中学到东西
一个完整的s2sm整合项目,含jar包。使用注释型事务管理。给大家参考了。
批量生产的RDS收音机模块,Altium软件PCB,批量生产的板子,STC15F2K60S2 + QN8025+M62429+红外接收,单pcb
ACCP+S2+复习资料(超全)ACCP+S2+复习资料(超全)
S2SH 框架+分页+ajax用户时实验证
struts2+hibernate3+spring3分页;附带数据库;能输出结果;数据库采用mysql;
运行环境JDK6+myeclipse8.6+tomcat6.0,jar包完整,导入之后可以直接跑起来。
ACCP5.0+S2+JSP指导练习答案
自己整理的jar包,新手也可用,都分类好了,Struts1.2+spring3.2+hibernate3.1就用S1SH文件夹的jar包...Struts2+Spring3.2+hibernate3.1就用S2SH文件夹的jar包;SpringMVC+Hibernate3.1就用SpringMVC+H文件夹下的jar。
IAP15f2k6s2+ENC28j60+UIP1.0简单的代码移植
STC15F2K60S2+GPS_数码管电子钟程序,自动对时.zip
STC15F2K60S2+GPS_数码管电子钟程序,自动对时.rar
STC15F2K60S2+GPS_数码管电子钟程序,自动对时.zip
s2sh分页s2sh分页s2sh分页s2sh分页s2sh分页s2sh分页s2sh分页