1.转自:http://www.cnblogs.com/shiyangxt/archive/2008/11/04/1316737.html
环境:MyEclipse6.5+Mysql5+struts2.0.11

实现分页用到三个类,分别为NewsDao.java(接口),NewsDaoImpl.java(实现),ListAction.java(调用方法)。

当然还有配好连接池的Mysql连接辅助类。在此不做过多介绍。

NewsDao.java

package com.sy.dao;

import java.util.List;

import com.sy.vo.News;

public interface NewsDao {

    public List<News> queryByPage(int pageSize,int pageNow);

    public int count();

}

NewsDaoImpl.java

package com.sy.dao.impl;

import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.List; import com.sy.dao.NewsDao;
import com.sy.util.DataBaseConnection;
import com.sy.util.StringUtil;
import com.sy.vo.News; public class NewsDaoImpl implements NewsDao { //获取分页新闻列表
@SuppressWarnings("unchecked")
public List<News> queryByPage(int i,int pageSize){
List<News> newss=new ArrayList(); PreparedStatement pstmt = null ;
String sql = null ;
ResultSet rs = null ;
DataBaseConnection dbc = null ;
dbc = new DataBaseConnection() ; sql = "select * from struts2new order by id asc limit " + i + "," + pageSize;
try
{ pstmt = dbc.getConnection().prepareStatement(sql); rs = pstmt.executeQuery() ;
while(rs.next())
{
News news=new News();
news.setId(rs.getInt("id"));
news.setName(rs.getString("name"));
news.setTitle(rs.getString("title"));
news.setDate(rs.getString("date"));
news.setEmail(rs.getString("email"));
news.setContent(rs.getString("content"));
i++;
newss.add(news);
}
rs.close() ;
pstmt.close() ;
}
catch(Exception e)
{
System.out.println(e) ;
}
finally
{
dbc.close();
}
return newss;
}
//查询总行数
public int count() {
int intRowCount = ;//总行数
PreparedStatement pstmt = null ;
String sql = null ;
ResultSet rs = null ;
DataBaseConnection dbc = null ;
dbc = new DataBaseConnection() ; sql = "select count(id) from struts2new order by id asc";
try
{
pstmt = dbc.getConnection().prepareStatement(sql);
rs = pstmt.executeQuery();
rs.next();//游标指向第一行
intRowCount=rs.getInt();//取得总行数
rs.close() ;
pstmt.close() ;
}
catch(Exception e)
{
System.out.println(e) ;
}
finally
{
dbc.close();
}
return intRowCount;
}
}

ListAction.java

package com.sy.action;

import java.util.List;

import com.opensymphony.xwork2.ActionSupport;
import com.sy.dao.AdminDao;
import com.sy.dao.NewsDao;
import com.sy.dao.impl.AdminDaoImpl;
import com.sy.dao.impl.NewsDaoImpl;
import com.sy.vo.Admin;
import com.sy.vo.News; public class ListAction extends ActionSupport { private static final long serialVersionUID = 1L;
int i=;//中间变量
private int k;//储存最大页面数
private int pageNow=; //页码数,初始为1
private int pageSize = ; //页面行数
private int intRowCount;//总行数
private int intPageCount;//总页数
private Admin admin;
private List<Admin> Adminss;
private News news;
@SuppressWarnings("unchecked")
private List<News> Newss; private int id;
private int aid; public News getNews() {
return news;
} public void setNews(News news) {
this.news = news;
} @SuppressWarnings("unchecked")
public List<News> getNewss() {
return Newss;
}
public void setNewss(List<News> newss) {
Newss = newss;
} public int getId() {
return id;
} public void setId(int id) {
this.id = id;
}
public Admin getAdmin() {
return admin;
} public void setAdmin(Admin admin) {
this.admin = admin;
} public List<Admin> getAdminss() {
return Adminss;
} public void setAdminss(List<Admin> adminss) {
Adminss = adminss;
}
public int getAid() {
return aid;
} public void setAid(int aid) {
this.aid = aid;
} 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 getIntRowCount() {
return intRowCount;
} public void setIntRowCount(int intRowCount) {
this.intRowCount = intRowCount;
} public int getIntPageCount() {
return intPageCount;
} public void setIntPageCount(int intPageCount) {
this.intPageCount = intPageCount;
}
public int getK() {
return k;
} public void setK(int k) {
this.k = k;
}
@SuppressWarnings("unchecked")
@Override
//显示新闻列表
public String execute() throws Exception { NewsDao npage=new NewsDaoImpl();
intRowCount=npage.count();
k=(intRowCount + pageSize - ) / pageSize;
intPageCount = (intRowCount + pageSize - ) / pageSize;//计算出总页数
if(pageNow<){
pageNow=;
} if(pageNow > intPageCount)
pageNow=intPageCount;
i = (pageNow -)*pageSize;
NewsDao nlist=new NewsDaoImpl();
if(null!=nlist.queryByPage(i,pageSize)){
Newss = nlist.queryByPage(i,pageSize);
return SUCCESS;
}else{
return "failure";
}
}
..
}

struts.xml

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE struts PUBLIC
"-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"
"http://struts.apache.org/dtds/struts-2.0.dtd">
<struts>
<package name="news" extends="struts-default"> ..
<!-- 查看新闻列表 -->
<action name="list" class="com.sy.action.ListAction">
<result>/listNews.jsp</result>
<result name="failure">/Showfailure.jsp</result>
</action> </package>
</struts>

显示页面listNews.jsp

<%@ page language="java" pageEncoding="UTF-8"%>
<%@ taglib prefix="s" uri="/struts-tags"%>
<%
String path = request.getContextPath();
String basePath = request.getScheme() + "://"
+ request.getServerName() + ":" + request.getServerPort()
+ path + "/";
%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<base href="<%=basePath%>">
<title>My JSP 'index.jsp' starting page</title>
</head>
<body> .. <center>
共<s:property value="intRowCount"/>记录&nbsp;&nbsp;
第<s:property value="pageNow"/>页&nbsp;&nbsp;
<s:url id="url_pre" value="list.action">
<s:param name="pageNow" value="pageNow-1"></s:param>
</s:url> <s:url id="url_next" value="list.action">
<s:param name="pageNow" value="pageNow+1"></s:param>
</s:url>
<s:iterator value="Newss" status="status">
<s:url id="url" value="list.action">
<s:param name="pageNow" value="pageNow"/>
</s:url>
</s:iterator>
<s:if test="pageNow==1">
<s:a href="%{url_pre}">最前一页</s:a>
</s:if>
<s:else>
<s:a href="%{url_pre}">上一页</s:a>
</s:else>
<s:if test="pageNow==k">
<s:a href="%{url_next}">最后一页</s:a>
</s:if>
<s:else>
<s:a href="%{url_next}">下一页</s:a>
</s:else>
</center>
</body>
</html>

效果:

struts2分页导航

首页 | 上一页  [] [] [] [] [] [] [] [] [] | 下一页 | 尾页  
上面效果中的 [] [] [] [] [] [] [] [] [] 这个效果用struts2的bean标签可以完成。如下: <s:bean name="org.apache.struts2.util.Counter" id="counter">
<s:param name="first" value="" />//循环开始 这用时要放变量来反映分页导航条的变化
<s:param name="last" value="" />//循环结束 这用时要放变量来反映分页导航条的变化 <s:iterator>//循环分页导航 <s:if test="pager.currentPage!=current-1">//不是当前页的显示效果
<a href="<s:property value="#
URL"/>&pageNum=<s:property/>">
[<s:property/>]</a>
</s:if>
<s:else>//当前页的显示效果
<font color="red"><s:property/></font>
</s:else>
</s:iterator>
</s:bean> 共大家参考。 .http://blog.csdn.net/hy0231/archive/2008/12/15/3522791.aspx ,view层 <s:url id="url_pre" value="queryMember.action">
<s:param name="pageCur" value="pageCur-1"></s:param>
</s:url>
<s:url id="url_next" value="queryMember.action">
<s:param name="pageCur" value="pageCur+1"></s:param>
</s:url>
<s:a href="%{url_pre}">上一页</s:a> <s:iterator value="memberList" status="st">
<s:url id="url" value="queryMember.action">
<s:param name="pageCur" value="pageCur"/>
</s:url>
</s:iterator>
<s:a href="%{url_next}">下一页</s:a> ,Action层
public class MemberListAction
{
private int pageCur = ;
private int totalCount = ;
private int totalPage = ;
private List memberList = null; public String execute() throws Exception
{
MemberDAO dao = new MemberDAO(); /*这里是做分页的处理,有总记录数temp,总页数totalPage,当前页数pageCur SysConstant.pageSize是一个常量,代表每页显示的记录数 */
//总数量
int temp = dao.getCount(id,name);
setTotalCount(temp); if((pageCur-)*SysConstant.pageSize >= temp)
{
pageCur = pageCur - ;
}
if(pageCur <= )
{
pageCur = ;
}
if(temp == )
{
totalPage = ;
}
else
{
totalPage =
(int) Math.ceil((double) temp / SysConstant.pageSize);
}
/**/
memberList = dao.getMember(id,name,pageCur);
return "SUCC";
} ,DAO层 这里直接写SQL。 MSQL的分页脚本:/*pageCur是当前页数,pageSize是每页显示记录数*/ select * from tmember limit ((pageCur-)*pageSize),(pageCur*pageSize) ORACLE的分页脚本: select * from (
select a.*,rownum as a_rownum from (
select * from tmember order by id
) a where rownum<=(pageCur*pageSize)
) b where b.a_rownum>(pageCur-)*pageSize

Struts2 实现分页的更多相关文章

  1. hibernate和struts2实现分页功能

    1.DAO层接口的设计,定义一个PersonDAO接口,里面声明了两个方法: public interface PersonDAO { public List<Person> queryB ...

  2. 5、Spring+Struts2+MyBatis+分页(mybatis无代理)增删改查

    1.创建如下项目结构 2.在src下的com.entity包下创建Dept.java package com.entity; /** * 部门表 * @author Holly老师 * */ publ ...

  3. struts2+hibernate(分页实现)

    //Dao类中实现了list集合和pagetotal方法 package zjf.strhib.Dao; import java.util.ArrayList; import java.util.Li ...

  4. struts2的分页标签

    1.准备tld文件 <?xml version="1.0" encoding="UTF-8" standalone="no"?> ...

  5. SSH:Struts2.2+Hibernate3.6+Spring3.1分页示例[转]

    参考资料 1 ssh分页(多个例子) http://useryouyou.iteye.com/blog/593954 2 ssh2分页例子 http://459104018-qq-com.iteye. ...

  6. pagebean pagetag java 后台代码实现分页 demo 前台标签分页 后台java分页

    java 后台代码实现分页 demo 实力 自己写的 标签分页 package com.cszoc.sockstore.util; import java.util.HashMap;import ja ...

  7. 用Hibernate和Struts2+jsp实现分页查询、修改删除

    1.首先用get的方法传递一个页数过去 2.通过Struts2跳转到Action 3.通过request接受主页面index传过的页数,此时页数是1, 然后调用service层的方法获取DAO层分页查 ...

  8. struts2+spring+hibernate 实现分页

    在这里要感谢下这位博友发表的博文 http://www.blogjava.net/rongxh7/archive/2008/11/29/243456.html 通过对他代码的阅读,从而自己实现了网页分 ...

  9. 分页进阶--ajax+jquery+struts2

    按照上次的分页逻辑,分页查询的业务大概需要几个“零件”:1.当前页:2.总页数:3.跳转页.后端需要处理的是:按照传送过来请求的页码返回相应地数据,并且接受初始化参数的请求:总页码.第一页的数据. 使 ...

随机推荐

  1. 实用技巧:简单而有用的nohup命令介绍(转)

    简单而有用的nohup命令在UNIX/LINUX中,普通进程用&符号放到后台运行,如果启动该程序的控制台logout,则该进程随即终止. 要实现守护进程,一种方法是按守护进程的规则去编程(本站 ...

  2. android 20 Intnet类重要的成员变量

    Intnet类重要的成员变量: <intent-filter> <action android:name="android.intent.action.MAIN" ...

  3. centos安装g++

    安装: yum -y install gcc automake autoconf libtool make 安装g++: yum install gcc gcc-c++

  4. iOS--NSAttributedString使用介绍

    iOS–NSAttributedString使用介绍 原文见: http://www.itnose.net/detail/6177538.html http://***/html/topnews201 ...

  5. Charles --- Mac 抓包工具

    安装 官方网站Charles 是一款收费软件,可以免费体验30天.网上有破解版. 使用 infoq 上有一篇很棒的教程:iOS开发工具——网络封包分析工具Charles 注意事项 这是我使用过程中遇到 ...

  6. Android 开发实践 ViewGroup 实现左右滑出窗口(一)

    利用假期把以前做的东西总结整理一下,先从简单的开始吧.实现的效果是这样的:   做了个截屏动画,比例有点不对了,凑合着看吧. 整个窗口有3部分组成,中间的主界面是个列表,左边的滑出界面是个菜单,右边的 ...

  7. js获取图片高度

    js获取图片高度时经常会获取的图片高度为0,原因是图片未加载完毕.第一次加载时,显示0(火狐等部分浏览器显示24).待加载完毕后,再刷新,显示图片高度258. var oImg = document. ...

  8. JS cookie 读写操作

    /*** ** 功能: cookie操作对象 ***/ var cookies = { /*** ** 功能: 写入cookie操作 ** 参数: name cookie名称 ** value coo ...

  9. 让我们写的程序生成单个的exe文件(C#winform程序举例)

    一准备: 首先你要有自己写好的代码程序 然后你需要在百度搜索Enigma Virtual Box 6.90并下载,运行后可看到如何的界面 注意:首次启动是英文的,更改语言后再次启动就是中文了. 二制作 ...

  10. 解决c#处理excel时故障 找不到可安装的 isam

    直接拷贝的以前代码,但因软件版本,系统环境的变化,导致提示“找不到可安装的 isam”. 我目前新的软件环境:win8.1+office2010+vs2013 解决办法是修改连接字符串: 处理exce ...