Pager-taglib.jar(分页组件)

这套解决方案,是按照MVC的模式来做的,基于STRUTS框架。分为三个部分,表现层用的是JSP,其中用了JSTL和pager taglib 做分页;控制层就 是用的很传统的Action;底层就用的是Spring+Hibernate。下面分三个部分慢慢说:

说到分页:
1  首先新建一个PageModel类

Java代码 复制代码
  1. package  com.dengmin.oa.utils;   
  2.   
  3. import  java.util.List;   
  4.   
  5. public   class  PageModel {   
  6.   
  7.      /**  
  8.      * 总 记录数  
  9.      */   
  10.      private   int  total;   
  11.      /**  
  12.      * 当 前页的记录集  
  13.      */   
  14.      private  List datas;   
  15.   
  16.      public  List getDatas() {   
  17.          return  datas;   
  18.     }   
  19.   
  20.      public   void  setDatas(List datas) {   
  21.          this .datas = datas;   
  22.     }   
  23.   
  24.      public   int  getTotal() {   
  25.          return  total;   
  26.     }   
  27.   
  28.      public   void  setTotal( int  total) {   
  29.          this .total = total;   
  30.     }   
  31. }  
Java代码 复制代码
  1. package  com.dengmin.oa.utils;   
  2.   
  3. import  java.util.List;   
  4.   
  5. public   class  PageModel {   
  6.   
  7.      /**  
  8.      * 总 记录数  
  9.      */   
  10.      private   int  total;   
  11.      /**  
  12.      * 当 前页的记录集  
  13.      */   
  14.      private  List datas;   
  15.   
  16.      public  List getDatas() {   
  17.          return  datas;   
  18.     }   
  19.   
  20.      public   void  setDatas(List datas) {   
  21.          this .datas = datas;   
  22.     }   
  23.   
  24.      public   int  getTotal() {   
  25.          return  total;   
  26.     }   
  27.   
  28.      public   void  setTotal( int  total) {   
  29.          this .total = total;   
  30.     }   
  31. }  
Java代码
  1. package  com.dengmin.oa.utils;  
  2.   
  3. import  java.util.List;  
  4.   
  5. public   class  PageModel {  
  6.   
  7.     /**  
  8.      * 总 记录数  
  9.      */   
  10.     private   int  total;  
  11.     /**  
  12.      * 当 前页的记录集  
  13.      */   
  14.     private  List datas;  
  15.   
  16.     public  List getDatas() {  
  17.         return  datas;  
  18.     }  
  19.   
  20.     public   void  setDatas(List datas) {  
  21.         this .datas = datas;  
  22.     }  
  23.   
  24.     public   int  getTotal() {  
  25.         return  total;  
  26.     }  
  27.   
  28.     public   void  setTotal( int  total) {  
  29.         this .total = total;  
  30.     }  
  31. }  
package com.dengmin.oa.utils;

import java.util.List;

public class PageModel {

	/**
	 * 总记录数
	 */
	private int total;
	/**
	 * 当前页的记录集
	 */
	private List datas;

	public List getDatas() {
		return datas;
	}

	public void setDatas(List datas) {
		this.datas = datas;
	}

	public int getTotal() {
		return total;
	}

	public void setTotal(int total) {
		this.total = total;
	}
}


2  底层是基于Spring+Hibernate来做的。在DAO这一层,为其增加两个方法,底层的分页查询用的是Hibernate提供的分页查询。

Java代码 复制代码
  1. public   interface  UserDao {   
  2.   
  3.      public   void  addUser(User user);   
  4.   
  5.      /**  
  6.      *   
  7.      * @param offset  从 第几条记录开始查询  
  8.      * @param pagesize  每 页显示多少条记录  
  9.      * @return  
  10.      */   
  11.      public  PageModel findAllUser( int  offset,  int  pagesize);   
  12. }  
Java代码 复制代码
  1. public   interface  UserDao {   
  2.   
  3.      public   void  addUser(User user);   
  4.   
  5.      /**  
  6.      *   
  7.      * @param offset  从 第几条记录开始查询  
  8.      * @param pagesize  每 页显示多少条记录  
  9.      * @return  
  10.      */   
  11.      public  PageModel findAllUser( int  offset,  int  pagesize);   
  12. }  
Java代码
  1. public   interface  UserDao {  
  2.   
  3.     public   void  addUser(User user);  
  4.   
  5.     /**  
  6.      *   
  7.      * @param offset  从第几条记录开始查询  
  8.      * @param pagesize  每页显示多少条记录  
  9.      * @return  
  10.      */   
  11.     public  PageModel findAllUser( int  offset,  int  pagesize);  
  12. }  
public interface UserDao {

	public void addUser(User user);

	/**
	 * 
	 * @param offset  从第几条记录开始查询
	 * @param pagesize  每页显示多少条记录
	 * @return
	 */
	public PageModel findAllUser(int offset, int pagesize);
}


3  UserDao的实现类

Java代码 复制代码
  1. public   class  UserDaoImpl  extends  HibernateDaoSupport  implements  UserDao {   
  2.   
  3.      public   void  addUser(User user) {   
  4.          this .getHibernateTemplate().save(user);   
  5.     }   
  6.        
  7.      public  PageModel findAllUser( int  offset,  int  pagesize) {   
  8.            
  9.          //得到总记录数   
  10.         String queryCountHql =  "select count(*) from User" ;   
  11.            
  12.         Query query = getSession().createQuery(queryCountHql);   
  13.          int  total = ((Long)query.uniqueResult()).intValue();   
  14.            
  15.         List datas = getSession().createQuery( "from User" )   
  16.                     .setFirstResult(offset)   
  17.                     .setMaxResults(pagesize)   
  18.                     .list();   
  19.          //得到结果集   
  20.         PageModel pm =  new  PageModel();   
  21.         pm.setTotal(total);   
  22.         pm.setDatas(datas);   
  23.            
  24.          return  pm;   
  25.     }   
  26.   
  27. }  
Java代码 复制代码
  1. public   class  UserDaoImpl  extends  HibernateDaoSupport  implements  UserDao {   
  2.   
  3.      public   void  addUser(User user) {   
  4.          this .getHibernateTemplate().save(user);   
  5.     }   
  6.        
  7.      public  PageModel findAllUser( int  offset,  int  pagesize) {   
  8.            
  9.          //得到总记录数   
  10.         String queryCountHql =  "select count(*) from User" ;   
  11.            
  12.         Query query = getSession().createQuery(queryCountHql);   
  13.          int  total = ((Long)query.uniqueResult()).intValue();   
  14.            
  15.         List datas = getSession().createQuery( "from User" )   
  16.                     .setFirstResult(offset)   
  17.                     .setMaxResults(pagesize)   
  18.                     .list();   
  19.          //得到结果集   
  20.         PageModel pm =  new  PageModel();   
  21.         pm.setTotal(total);   
  22.         pm.setDatas(datas);   
  23.            
  24.          return  pm;   
  25.     }   
  26.   
  27. }  
Java代码
  1. public   class  UserDaoImpl  extends  HibernateDaoSupport  implements  UserDao {  
  2.   
  3.     public   void  addUser(User user) {  
  4.         this .getHibernateTemplate().save(user);  
  5.     }  
  6.       
  7.     public  PageModel findAllUser( int  offset,  int  pagesize) {  
  8.           
  9.         //得到总记录数   
  10.         String queryCountHql = "select count(*) from User" ;  
  11.           
  12.         Query query = getSession().createQuery(queryCountHql);  
  13.         int  total = ((Long)query.uniqueResult()).intValue();  
  14.           
  15.         List datas = getSession().createQuery("from User" )  
  16.                     .setFirstResult(offset)  
  17.                     .setMaxResults(pagesize)  
  18.                     .list();  
  19.         //得到结果集   
  20.         PageModel pm = new  PageModel();  
  21.         pm.setTotal(total);  
  22.         pm.setDatas(datas);  
  23.           
  24.         return  pm;  
  25.     }  
  26.   
  27. }  
public class UserDaoImpl extends HibernateDaoSupport implements UserDao {

	public void addUser(User user) {
		this.getHibernateTemplate().save(user);
	}
	
	public PageModel findAllUser(int offset, int pagesize) {
		
		//得到总记录数
		String queryCountHql = "select count(*) from User";
		
		Query query = getSession().createQuery(queryCountHql);
		int total = ((Long)query.uniqueResult()).intValue();
		
		List datas = getSession().createQuery("from User")
					.setFirstResult(offset)
					.setMaxResults(pagesize)
					.list();
		//得到结果集
		PageModel pm = new PageModel();
		pm.setTotal(total);
		pm.setDatas(datas);
		
		return pm;
	}

}



ok!底层的实现工作就做好了

在控制层中UserAction从DispatchAction继承重写它的 unspecified方法
通过spring注入UserDao 代码如下:

Java代码 复制代码
  1. public   class  UserAction  extends  DispatchAction {   
  2.   
  3.      private  UserDao userDao;   
  4.      @Override   
  5.      protected  ActionForward unspecified(ActionMapping mapping, ActionForm form,   
  6.             HttpServletRequest request, HttpServletResponse response)  throws  Exception {   
  7.            
  8.          int  offset =  0 ;    
  9.            
  10.          try  {   
  11.             offset = Integer.parseInt(request.getParameter( "pager .offset" ));   
  12.         }  catch  (Exception e) {   
  13.         }   
  14.          //这里我按照每页显示10条   
  15.         PageModel pm = userDao.findAllUser(offset,  10 );   
  16.         request.setAttribute( "pm" , pm);   
  17.            
  18.          return  mapping.findForward( "success" );   
  19.     }   
  20.        
  21.      public   void  setUserDao(UserDao userDao) {   
  22.          this .userDao = userDao;   
  23.     }   
  24.        
  25. }  
Java代码 复制代码
  1. public   class  UserAction  extends  DispatchAction {   
  2.   
  3.      private  UserDao userDao;   
  4.      @Override   
  5.      protected  ActionForward unspecified(ActionMapping mapping, ActionForm form,   
  6.             HttpServletRequest request, HttpServletResponse response)  throws  Exception {   
  7.            
  8.          int  offset =  0 ;    
  9.            
  10.          try  {   
  11.             offset = Integer.parseInt(request.getParameter( "pager .offset" ));   
  12.         }  catch  (Exception e) {   
  13.         }   
  14.          //这里我按照每页显示10条   
  15.         PageModel pm = userDao.findAllUser(offset,  10 );   
  16.         request.setAttribute( "pm" , pm);   
  17.            
  18.          return  mapping.findForward( "success" );   
  19.     }   
  20.        
  21.      public   void  setUserDao(UserDao userDao) {   
  22.          this .userDao = userDao;   
  23.     }   
  24.        
  25. }  
Java代码
  1. public   class  UserAction  extends  DispatchAction {  
  2.   
  3.     private  UserDao userDao;  
  4.     @Override   
  5.     protected  ActionForward unspecified(ActionMapping mapping, ActionForm form,  
  6.             HttpServletRequest request, HttpServletResponse response) throws  Exception {  
  7.           
  8.         int  offset =  0 ;   
  9.           
  10.         try  {  
  11.             offset = Integer.parseInt(request.getParameter("pager .offset" ));  
  12.         } catch  (Exception e) {  
  13.         }  
  14.         //这里我按照每页显示10条   
  15.         PageModel pm = userDao.findAllUser(offset, 10 );  
  16.         request.setAttribute("pm" , pm);  
  17.           
  18.         return  mapping.findForward( "success" );  
  19.     }  
  20.       
  21.     public   void  setUserDao(UserDao userDao) {  
  22.         this .userDao = userDao;  
  23.     }  
  24.       
  25. }  
public class UserAction extends DispatchAction {

	private UserDao userDao;
	@Override
	protected ActionForward unspecified(ActionMapping mapping, ActionForm form,
			HttpServletRequest request, HttpServletResponse response) throws Exception {
		
		int offset = 0; 
		
		try {
			offset = Integer.parseInt(request.getParameter("pager
.offset"));
		} catch (Exception e) {
		}
		//这里我按照每页显示10条
		PageModel pm = userDao.findAllUser(offset, 10);
		request.setAttribute("pm", pm);
		
		return mapping.findForward("success");
	}
	
	public void setUserDao(UserDao userDao) {
		this.userDao = userDao;
	}
	
}



spring中的配置如下

Java代码 复制代码
  1. <!-- 配置sessionFactory -->   
  2.     <bean id= "sessionFactory"   
  3.          class = "org.springframework.orm.hibernate3.LocalSessionFactoryBean" >   
  4.         <property name= "configLocation" >   
  5.             <value>classpath:hibernate.cfg.xml</value>   
  6.         </property>   
  7.     </bean>   
  8.     <!-- 配置事务管理器 -->   
  9.     <bean id= "transactionManager"   
  10.          class = "org.springframework.orm.hibernate3.HibernateTransactionManager" >   
  11.         <property name= "sessionFactory" >   
  12.             <ref bean= "sessionFactory"  />   
  13.         </property>   
  14.     </bean>   
  15.   
  16.     <!-- 配置事务的传播特性 -->   
  17.     <tx:advice id= "txAdvice"  transaction-manager= "transactionManager" >   
  18.         <tx:attributes>   
  19.             <tx:method name= "*"  propagation= "REQUIRED"  />   
  20.         </tx:attributes>   
  21.     </tx:advice>   
  22.   
  23.   
  24. <bean id= "userDao"   class = "com.dengmin.pager .dao.UserDaoImpl" >   
  25.         <property name= "sessionFactory"  ref= "sessionFactory"  />   
  26.     </bean>   
  27.   
  28.     <bean name= "/userManager"   
  29.          class = "com.dengmin.pager .actions.UserAction"  scope= "prototype" >   
  30.         <property name= "userDao"  ref= "userDao"  />   
  31.     </bean>  
Java代码 复制代码
  1. <!-- 配置sessionFactory -->   
  2.     <bean id= "sessionFactory"   
  3.          class = "org.springframework.orm.hibernate3.LocalSessionFactoryBean" >   
  4.         <property name= "configLocation" >   
  5.             <value>classpath:hibernate.cfg.xml</value>   
  6.         </property>   
  7.     </bean>   
  8.     <!-- 配置事务管理器 -->   
  9.     <bean id= "transactionManager"   
  10.          class = "org.springframework.orm.hibernate3.HibernateTransactionManager" >   
  11.         <property name= "sessionFactory" >   
  12.             <ref bean= "sessionFactory"  />   
  13.         </property>   
  14.     </bean>   
  15.   
  16.     <!-- 配置事务的传播特性 -->   
  17.     <tx:advice id= "txAdvice"  transaction-manager= "transactionManager" >   
  18.         <tx:attributes>   
  19.             <tx:method name= "*"  propagation= "REQUIRED"  />   
  20.         </tx:attributes>   
  21.     </tx:advice>   
  22.   
  23.   
  24. <bean id= "userDao"   class = "com.dengmin.pager .dao.UserDaoImpl" >   
  25.         <property name= "sessionFactory"  ref= "sessionFactory"  />   
  26.     </bean>   
  27.   
  28.     <bean name= "/userManager"   
  29.          class = "com.dengmin.pager .actions.UserAction"  scope= "prototype" >   
  30.         <property name= "userDao"  ref= "userDao"  />   
  31.     </bean>  
Java代码
  1. <!-- 配 置sessionFactory -->  
  2.     <bean id="sessionFactory"   
  3.         class = "org.springframework.orm.hibernate3.LocalSessionFactoryBean" >  
  4.         <property name="configLocation" >  
  5.             <value>classpath:hibernate.cfg.xml</value>  
  6.         </property>  
  7.     </bean>  
  8.     <!-- 配 置事务管理器 -->  
  9.     <bean id="transactionManager"   
  10.         class = "org.springframework.orm.hibernate3.HibernateTransactionManager" >  
  11.         <property name="sessionFactory" >  
  12.             <ref bean="sessionFactory"  />  
  13.         </property>  
  14.     </bean>  
  15.   
  16.     <!-- 配 置事务的传播特性 -->  
  17.     <tx:advice id="txAdvice"  transaction-manager= "transactionManager" >  
  18.         <tx:attributes>  
  19.             <tx:method name="*"  propagation= "REQUIRED"  />  
  20.         </tx:attributes>  
  21.     </tx:advice>  
  22.   
  23.   
  24. <bean id="userDao"   class = "com.dengmin.pager .dao.UserDaoImpl" >  
  25.         <property name="sessionFactory"  ref= "sessionFactory"  />  
  26.     </bean>  
  27.   
  28.     <bean name="/userManager"   
  29.         class = "com.dengmin.pager .actions.UserAction"  scope= "prototype" >  
  30.         <property name="userDao"  ref= "userDao"  />  
  31.     </bean>  
<!-- 配置sessionFactory -->
	<bean id="sessionFactory"
		class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
		<property name="configLocation">
			<value>classpath:hibernate.cfg.xml</value>
		</property>
	</bean>
	<!-- 配置事务管理器 -->
	<bean id="transactionManager"
		class="org.springframework.orm.hibernate3.HibernateTransactionManager">
		<property name="sessionFactory">
			<ref bean="sessionFactory" />
		</property>
	</bean>

	<!-- 配置事务的传播特性 -->
	<tx:advice id="txAdvice" transaction-manager="transactionManager">
		<tx:attributes>
			<tx:method name="*" propagation="REQUIRED" />
		</tx:attributes>
	</tx:advice>


<bean id="userDao" class="com.dengmin.pager
.dao.UserDaoImpl">
		<property name="sessionFactory" ref="sessionFactory" />
	</bean>

	<bean name="/userManager"
		class="com.dengmin.pager
.actions.UserAction" scope="prototype">
		<property name="userDao" ref="userDao" />
	</bean>



最后是jsp页面做数据显示
这里采用了jstl和pager -taglib 的 标签库
首先将其引入:

Java代码 复制代码
  1. <%@ taglib  prefix= "c"   uri= "http://java.sun.com/jsp/jstl/core"  %>   
  2. <%@ taglib  prefix= "pg"  uri= "http://jsptags.com/tags/navigation/pager "  %>  
Java代码 复制代码
  1. <%@ taglib  prefix= "c"   uri= "http://java.sun.com/jsp/jstl/core"  %>   
  2. <%@ taglib  prefix= "pg"  uri= "http://jsptags.com/tags/navigation/pager "  %>  
Java代码
  1. <%@ taglib  prefix= "c"   uri= "http://java.sun.com/jsp/jstl/core"  %>  
  2. <%@ taglib  prefix="pg"  uri= "http://jsptags.com/tags/navigation/pager "  %>  
<%@ taglib
 prefix="c"  uri="http://java.sun.com/jsp/jstl/core" %>
<%@ taglib
 prefix="pg" uri="http://jsptags.com/tags/navigation/pager
" %>

 

Html代码 复制代码
  1.    < body >   
  2.      < h1 > User Manager </ h1 >   
  3.      < hr />   
  4.        
  5.      < table   width = "778"   border = "0"   cellPadding = "0"   cellSpacing = "1"   bgcolor = "#6386d6" >   
  6.      < tr   bgcolor = "#EFF3F7" >   
  7.          < TD   align = "center" > ID </ TD >   
  8.          < TD   align = "center" > 名 称 </ TD >   
  9.          < TD
分享到:
评论

你可能感兴趣的:(java,spring,bean,Hibernate,orm)