blogjava's web log

blogjava's web log
...

偷窥struts+hibernate分页(第一种方法)

根据原文有点改动。原文忘记在那里看到了。看到提个醒


新建表

DROP DATABASE IF EXISTS `wjcms`;
CREATE DATABASE `wjcms` /*!40100 DEFAULT CHARACTER SET gb2312 */;
USE `wjcms`;

#
Table structure for table t_article
#

CREATE TABLE `t_article` (
  `a_id` 
int(11NOT NULL auto_increment,
  `a_sort` 
int(11NOT NULL default '0',
  `a_title` 
varchar(50default NULL,
  `a_body` 
text,
  `a_author` 
varchar(11default '',
  `a_hit` 
int(11NOT NULL default '0',
  `c_id` 
int(11default '0',
  `a_date` 
varchar(20default NULL,
  
PRIMARY KEY  (`a_id`)


实体

public class articleVO {
    private int a_id;
    private int a_sort;
    private int a_hit;
    private int c_id;
    private String a_title;
    private String a_body;
    private String a_author;
    private String a_date;
    // getter setter


新建page.java

package page.dal;

public class page {
    
private int totalRows; //总行数
    private int pageSize = 10//每页显示的行数
    private int currentPage; //当前页号
    private int totalPages; //总页数
    private int startRow; //当前页在数据库中的起始行

    
public page(int _totalRows) {
     totalRows 
= _totalRows;
     totalPages
=totalRows/pageSize;
     
int mod=totalRows%pageSize;
     
if(mod>0){
       totalPages
++;
     }
     currentPage 
= 1;
     startRow 
= 0;
   }

   
public int getStartRow() {
     
return startRow;
   }

   
public int getTotalPages() {
     
return totalPages;
   }

   
public int getCurrentPage() {
     
return currentPage;
   }

   
public int getPageSize() {
     
return pageSize;
   }

   
public void setTotalRows(int totalRows) {
     
this.totalRows = totalRows;
   }

   
public void setStartRow(int startRow) {
     
this.startRow = startRow;
   }

   
public void setTotalPages(int totalPages) {
     
this.totalPages = totalPages;
   }

   
public void setCurrentPage(int currentPage) {
     
this.currentPage = currentPage;
   }

   
public void setPageSize(int pageSize) {
     
this.pageSize = pageSize;
   }

   
public int getTotalRows() {
     
return totalRows;
   }

   
public void first() {
     currentPage 
= 1;
     startRow 
= 0;
   }

   
public void previous() {
     
if (currentPage == 1) {
       
return;
     }
     currentPage
--;
     startRow 
= (currentPage - 1* pageSize;
   }

   
public void next() {
     
if (currentPage < totalPages) {
       currentPage
++;
     }
     startRow 
= (currentPage - 1* pageSize;
   }

   
public void last() {
     currentPage 
= totalPages;
     startRow 
= (currentPage - 1* pageSize;
   }

   
public void refresh(int _currentPage) {
     currentPage 
= _currentPage;
     
if (currentPage > totalPages) {
       last();
     }
   }

 }



新建 pageHelp.java

package page.dal;
import javax.servlet.http.*;

public class PagerHelp {
    
public static page getPager(HttpServletRequest httpServletRequest,int totalRows) {

     
//定义pager对象,用于传到页面
     page pager = new page(totalRows);

     
//从Request对象中获取当前页号
     String currentPage = httpServletRequest.getParameter("currentPage");

     
//如果当前页号为空,表示为首次查询该页
     
//如果不为空,则刷新page对象,输入当前页号等信息
     if (currentPage != null) {
       pager.refresh(Integer.parseInt(currentPage));
     }

     
//获取当前执行的方法,首页,前一页,后一页,尾页。
     String pagerMethod = httpServletRequest.getParameter("pageMethod");

     
if (pagerMethod != null) {
       
if (pagerMethod.equals("first")) {
         pager.first();
       } 
else if (pagerMethod.equals("previous")) {
         pager.previous();
       } 
else if (pagerMethod.equals("next")) {
         pager.next();
       } 
else if (pagerMethod.equals("last")) {
         pager.last();
       }
     }
     
return pager;
   }

}



新建 util.java
package page.dal;
import net.sf.hibernate.Query;
import net.sf.hibernate.cfg.Configuration;
import java.util.List;
import net.sf.hibernate.HibernateException;
import net.sf.hibernate.SessionFactory;
import net.sf.hibernate.Session;
import java.util.*;
public class util {
    
public util() {
    }
     
private Session ss=null;
    
public Session getSession()
  {
      
//  Configuration config=null;
      SessionFactory sessionFactory;
      
try {
          Configuration cfg 
= new Configuration();
          sessionFactory 
= cfg.addClass(articleVO.class).
                           buildSessionFactory();
          
// SessionFactory sessionFactory=config.buildSessionFactory();
          ss = sessionFactory.openSession();
          
return ss;
      } 
catch (HibernateException ex) {
          System.out.print(
"getsession出错了。。" + ex.getMessage());
          
return null;
      }
  }

  
public int getCount()
  {
      String sql
="select count(*) from articleVO" ;
      
this.getSession();

    
try {
     
// ss.createQuery("select count(a)as cont from articleVO a ");
      int rows= ((Integer) ss.iterate(sql).next()).intValue();
      ss.flush();
      
return rows;

    } 
catch (HibernateException ex) {
        System.out.print(
"ex::"+ex.getMessage());
        
return 0;
    }


  }

  
public Collection  getList(int pagesize,int currow) throws HibernateException {
      Collection vehicleList 
= null;
      
this.getSession();
      Query q
=ss.createQuery("from articleVO");
      q.setFirstResult(currow);
      q.setMaxResults(pagesize);
      vehicleList
=q.list();
      ss.flush();
      
return vehicleList;
  }

}


新建 struts  PageAction.java


package page.dal;

import org.apache.struts.action.ActionMapping;
import org.apache.struts.action.ActionForm;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.apache.struts.action.ActionForward;
import org.apache.struts.action.Action;
import page.dal.*;
import java.util.*;
import net.sf.hibernate.*;

public class pageAction extends Action {
    
public ActionForward execute(ActionMapping mapping, ActionForm form,
                                 HttpServletRequest request,
                                 HttpServletResponse response) {
        Collection clInfos 
= null;//用于输出到页面的记录集合
        int totalRows;//记录总行数
        util dal=new util();
        totalRows
=dal.getCount();
        System.out.print(
"总行数=="+totalRows);
        page p
=PagerHelp.getPager(request,totalRows);
        
try {
            clInfos 
= dal.getList(p.getPageSize(), p.getStartRow());

        } 
catch (HibernateException ex) {
            System.out.print(
"action里的错误="+ex.getMessage());
        }
        request.setAttribute(
"page",p);
        request.setAttribute(
"list",clInfos);
        
return mapping.findForward("page");
        
//pageForm pageForm = (pageForm) form;
      
//  throw new java.lang.UnsupportedOperationException(
              
//  "Method $execute() not yet implemented.");
    }
}


前台页面

<%@ taglib uri="/WEB-INF/struts-tiles.tld" prefix="tiles" %>
<%@ taglib uri="/WEB-INF/struts-nested.tld" prefix="nested" %>
<%@ taglib uri="/WEB-INF/struts-logic.tld" prefix="logic" %>
<%@ taglib uri="/WEB-INF/struts-bean.tld" prefix="bean" %>
<%@ taglib uri="/WEB-INF/struts-html.tld" prefix="html" %>
<%@ page contentType="text/html; charset=GBK" %>
<html:html>
<head>
<title>
page
</title>
</head>
<body>
<table align="center" border="2">
<tr>
<th>a_title</th>
<th>a_body</th>
<th>a_a_date</th>
<th>a_author</th>
</tr>

<logic:iterate id="listd" name="list">
<tr>
<td>
<bean:write name="listd" property="a_title"/>
</td>
<td>
<bean:write name="listd" property="a_author"/>
</td>
<td>
<bean:write name="listd" property="a_date"/>
</td>
<td>
<bean:write name="listd" property="a_date"/>
</td>
</tr>
</logic:iterate>

</table>

<bean:write name="page" property="currentPage"/>
<bean:write name="page" property="totalPages" />
<html:link action="/pageAction.do?pageMethod=first"
paramName
="page" paramProperty="currentPage" paramId="currentPage">首页</html:link>
   
<html:link action="/pageAction.do?pageMethod=previous"
paramName
="page" paramProperty="currentPage" paramId="currentPage">上一页</html:link>
   
<html:link action="/pageAction.do?pageMethod=next"
paramName
="page" paramProperty="currentPage" paramId="currentPage">下一页</html:link>

   
<html:link action="/pageAction.do?pageMethod=last"
paramName
="page" paramProperty="currentPage" paramId="currentPage">尾页</html:link>
</body>
</html:html>



启动浏览 pageAction.do  运行OK。



****************************************************************************************


配置文件


<?xml version="1.0" encoding="UTF-8"?>

<!DOCTYPE hibernate-mapping PUBLIC
    "-//Hibernate/Hibernate Mapping DTD 2.0//EN"
    "http://hibernate.sourceforge.net/hibernate-mapping-2.0.dtd"
>
<hibernate-mapping>

    
<class name="page.dal.articleVO" table="t_article" >


    
<id name="a_id" column="a_id" unsaved-value="0" >
      
<generator class="native"/>
 
</id>
     
<property name="c_id"    column="c_id"/>
     
<property name="a_title" column="a_title"/>
     
<property name="a_sort"  column="a_sort"/>
     
<property name="a_date"  column="a_date"/>
     
<property name="a_body"  column="a_body"/>
     
<property name="a_hit"   column="a_hit"/>
     
<property name="a_author" column="a_author"/>
   
    
  
</class>

</hibernate-mapping>

hibernate.dialect net.sf.hibernate.dialect.MySQLDialect
hibernate.connection.driver_class org.gjt.mm.mysql.Driver
hibernate.connection.url jdbc:mysql://localhost:
3306/wjcms
hibernate.connection.username root
hibernate.connection.password 
hibernate.connection.pool_size 
1
hibernate.proxool.pool_alias pool1
hibernate.show_sql true
hibernate.max_fetch_depth 
1
hibernate.cache.use_query_cache true



posted on 2006-08-29 11:38 record java and net 阅读(16686) 评论(18)  编辑  收藏 所属分类: javaSpring

评论

# re: 偷窥struts+hibernate分页(第一种方法)[未登录] 2007-06-21 22:06 cc

呵呵 弄了2天 终于结合到了 我的程序里了 非常的感谢你!!!

顺便问一下 你的page是actionForm吗 我对你的page的数据封装(取值,赋值)不是很明白 你能不能给我讲一讲 谢谢你

我是名新手 希望您能给我解惑!!

QQ:531672250  回复  更多评论   

# re: 偷窥struts+hibernate分页(第一种方法) 2007-08-17 22:56 书亭

感谢分享  回复  更多评论   

# re: 偷窥struts+hibernate分页(第一种方法) 2008-02-13 17:26 nicelife

安装你的实例一步步做了一遍练习,
测试结果,100万条以内的记录5秒内能查询出来,500万条以内10秒,有点慢,如果换成小型机或服务器能提高很多,不知道是否正常,能够改进提高速度。  回复  更多评论   

# re: 偷窥struts+hibernate分页(第一种方法) 2008-02-13 17:27 nicelife

-- Test PC Environment
winxp, Oracle 9.2.0.1.0, j2sdk 1.5.0_11, Tomcat5.0, Eclipse 3.2, PL/SQL Developer 7.0, Struts 1.2.9, Hibernate 3.2.2  回复  更多评论   

# re: 偷窥struts+hibernate分页(第一种方法) 2008-02-27 10:47 weber

好像URL中的currentPage和页面中的第?页显示不一致,要显示一致如何做到?  回复  更多评论   

# re: 偷窥struts+hibernate分页(第一种方法) 2008-03-10 15:03 wenlong342

多谢搂主了,很好的程序.  回复  更多评论   

# re: 偷窥struts+hibernate分页(第一种方法) 2008-03-13 13:46 hyc

不太实用....  回复  更多评论   

# re: 偷窥struts+hibernate分页(第一种方法) 2008-03-27 13:13 COOL

写得还行,挺不错,  回复  更多评论   

# re: 偷窥struts+hibernate分页(第一种方法) 2008-05-15 20:12 jiangdong

楼主可不可以把可以直接运行源文件发一份给我,这上面有错误,不胜感激!
邮箱:
jiangdongsx@gmail.com  回复  更多评论   

# re: 偷窥struts+hibernate分页(第一种方法) 2008-06-18 11:09 fy_iceworld

您好。请问在这句中 int rows= ((Integer) ss.iterate(sql).next()).intValue();

ss.iterate这个方法为什么eclipse提示找不到??
  回复  更多评论   

# re: 偷窥struts+hibernate分页(第一种方法) 2008-10-14 16:05 asdf

很不错哦...  回复  更多评论   

# re: 偷窥struts+hibernate分页(第一种方法) 关于这个entire的一些具体问题 2009-04-17 21:49 ss

假如,我要分页的内容不是整张表,而是一个有Where条件的集合,该怎么改?  回复  更多评论   

# re: 偷窥struts+hibernate分页(第一种方法) 2009-05-18 00:48 angely

不知道为什么,我currentPage一直获取到的都是空置!

//从Request对象中获取当前页号
String currentPage = httpServletRequest.getParameter("currentPage");  回复  更多评论   

# re: 偷窥struts+hibernate分页(第一种方法) 2009-06-12 16:29 hsj

分页最郁闷就是又要分页,又要知道总记录数.楼主办法有两个问题:
1.用两次查询来分别获得总记录数和记录集.数据量大的话相当慢.
2.得到记录总数的方法(count(*))用的范围不广,如果我的SQL里有goup by , order by 怎么办?  回复  更多评论   

# re: 偷窥struts+hibernate分页(第一种方法) 2009-10-25 19:46 struts1.x

晕,struts1.x呀,也不注明,看完才明白。  回复  更多评论   

# re: 偷窥struts+hibernate分页(第一种方法) 2010-06-23 20:50

查询的时候想加个查询条件 ,就是typeid 点下一页的时候就获取不到了 .怎么解决  回复  更多评论   

# re: 偷窥struts+hibernate分页(第一种方法)[未登录] 2011-01-06 14:28

楼主看了你的代码 感觉很好  但是我拿下来运行 都是有错  你能不能把你的原代码(所以的)都发给我邮箱里一下 谢谢了414832466@qq.com   回复  更多评论   

# re: 偷窥struts+hibernate分页(第一种方法) 2012-02-20 11:26 walkingdog

代码很乱  回复  更多评论   


只有注册用户登录后才能发表评论。


网站导航:
 

导航

常用链接

留言簿(44)

新闻档案

2.动态语言

3.工具箱

9.文档教程

友情链接

搜索

最新评论