亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

java-SSH2實(shí)現(xiàn)數(shù)據(jù)庫(kù)和界面的分頁

 更新時(shí)間:2016年10月20日 11:43:03   作者:liuchangqing123  
本文主要是介紹SSH2實(shí)現(xiàn)數(shù)據(jù)庫(kù)和界面的分頁的代碼,分頁在web應(yīng)用中是經(jīng)常要做的事情,實(shí)用性比較大,有需要的朋友可以來了解一下。

分頁應(yīng)該是在我們開發(fā)web應(yīng)用時(shí)經(jīng)常要做的工作,能夠比較簡(jiǎn)潔的實(shí)現(xiàn)數(shù)據(jù)庫(kù)和視圖層的分頁十分重要。

在數(shù)據(jù)庫(kù)層利用hibernate進(jìn)行數(shù)據(jù)庫(kù)的分頁,將從數(shù)據(jù)庫(kù)中查詢出的數(shù)據(jù)封裝為javabean;在視圖層就可以方便的實(shí)現(xiàn)分頁。

創(chuàng)建PageBean

package com.fishing.common.bean; 
 
import java.util.List; 
@SuppressWarnings("unchecked") 
public class PageBean { 
   
  private List list; // 要返回的某一頁的記錄列表 
 
  private int allRow; // 總記錄數(shù) 
  private int totalPage; // 總頁數(shù) 
  private int currentPage; // 當(dāng)前頁 
  private int pageSize; // 每頁記錄數(shù) 
 
   
  private boolean isFirstPage; // 是否為第一頁 
  private boolean isLastPage; // 是否為最后一頁 
  private boolean hasPreviousPage; // 是否有前一頁 
  private boolean hasNextPage; // 是否有下一頁 
 
  public List getList() { 
    return list; 
  } 
 
  public void setList(List list) { 
    this.list = list; 
  } 
 
  public int getAllRow() { 
    return allRow; 
  } 
 
  public void setAllRow(int allRow) { 
    this.allRow = allRow; 
  } 
 
  public int getTotalPage() { 
    return totalPage; 
  } 
 
  public void setTotalPage(int totalPage) { 
    this.totalPage = totalPage; 
  } 
 
  public int getCurrentPage() { 
    return currentPage; 
  } 
 
  public void setCurrentPage(int currentPage) { 
    this.currentPage = currentPage; 
  } 
 
  public int getPageSize() { 
    return pageSize; 
  } 
 
  public void setPageSize(int pageSize) { 
    this.pageSize = pageSize; 
  } 
 
  /** */ 
  /** 
   * 初始化分頁信息 
   */ 
  public void init() { 
    this.isFirstPage = isFirstPage(); 
    this.isLastPage = isLastPage(); 
    this.hasPreviousPage = isHasPreviousPage(); 
    this.hasNextPage = isHasNextPage(); 
  } 
 
  /** */ 
  /** 
   * 以下判斷頁的信息,只需getter方法(is方法)即可 
   * 
   * @return 
   */ 
 
  public boolean isFirstPage() {   
    return (currentPage == 1);// 如是當(dāng)前頁是第1頁   
  }   
  public boolean isLastPage() {   
 return currentPage == totalPage; //如果當(dāng)前頁是最后一頁   
}   
  public boolean isHasPreviousPage() {   
 return currentPage != 1; //只要當(dāng)前頁不是第1頁   
}   
  public boolean isHasNextPage() {   
 return currentPage != totalPage; //只要當(dāng)前頁不是最后1頁   
}   
  /** */ 
  /** 
   * 計(jì)算總頁數(shù),靜態(tài)方法,供外部直接通過類名調(diào)用 
   * 
   * @param pageSize 
   *      每頁記錄數(shù) 
   * @param allRow 
   *      總記錄數(shù) 
   * @return 總頁數(shù) 
   */ 
  public static int countTotalPage(final int pageSize, final int allRow) { 
    int totalPage = allRow % pageSize == 0 ? allRow / pageSize : allRow 
        / pageSize + 1; 
    return totalPage; 
  } 
 
  /** */ 
  /** 
   * 計(jì)算當(dāng)前頁開始記錄 
   * 
   * @param pageSize 
   *      每頁記錄數(shù) 
   * @param currentPage 
   *      當(dāng)前第幾頁 
   * @return 當(dāng)前頁開始記錄號(hào) 
   */ 
  public static int countOffset(final int pageSize, final int currentPage) { 
    final int offset = pageSize * (currentPage - 1); 
    return offset; 
  } 
 
  /** */ 
  /** 
   * 計(jì)算當(dāng)前頁,若為0或者請(qǐng)求的URL中沒有"?page=",則用1代替 
   * 
   * @param page 
   *      傳入的參數(shù)(可能為空,即0,則返回1) 
   * @return 當(dāng)前頁 
   */ 
  public static int countCurrentPage(int page) { 
    final int curPage = (page == 0 ? 1 : page); 
    return curPage; 
  } 
} 

在Dao的抽象接口BaseDao中添加方法:

public List queryForPage(final String hql, final int offset, 
      final int length); 
在Dao的實(shí)現(xiàn)類JianSheDWDaoImpl中實(shí)現(xiàn)方法
public List queryForPage(final String hql, final int offset, 
      final int length) { 
    List list = getHibernateTemplate().executeFind(new HibernateCallback() { 
 
      public Object doInHibernate(Session session) 
          throws HibernateException, SQLException { 
        Query query = session.createQuery(hql); 
        query.setFirstResult(offset); 
        query.setMaxResults(length); 
        List list = query.list(); 
        return list; 
 
      } 
    }); 
 
    return list; 
  } 

在service抽象層接口JianSheDWService中添加方法:

public PageBean queryForPage(int pageSize,int currentPage);  

在service實(shí)現(xiàn)類中實(shí)現(xiàn)方法:

public PageBean queryForPage(int pageSize, int page) { 
    final String hql = "from JianSheDWBean"; // 查詢語句 
    int allRow = this.baseDao.getAllRowCount(hql); // 總記錄數(shù) 
    int totalPage = PageBean.countTotalPage(pageSize, allRow); // 總頁數(shù) 
    final int offset = PageBean.countOffset(pageSize, page); // 當(dāng)前頁開始記錄 
    final int length = pageSize; // 每頁記錄數(shù) 
    final int currentPage = PageBean.countCurrentPage(page); 
    List<JianSheDWBean> list = this.baseDao.queryForPage(hql, offset, length); // "一頁"的記錄 
 
    // 把分頁信息保存到Bean中 
    PageBean pageBean = new PageBean(); 
    pageBean.setPageSize(pageSize); 
    pageBean.setCurrentPage(currentPage); 
    pageBean.setAllRow(allRow); 
    pageBean.setTotalPage(totalPage); 
    pageBean.setList(list); 
    pageBean.init(); 
    return pageBean; 
 
  } 

在視圖層action中建立分頁模型

package com.fishing.action.lcq;  
import com.fishing.common.bean.JianSheDWBean; 
import com.fishing.common.bean.PageBean; 
import com.fishing.service.lcq.JianSheDWService; 
import com.opensymphony.xwork2.ActionSupport; 
 
@SuppressWarnings("serial") 
public class GetInfoJSDWListAction extends ActionSupport { 
 
  private int page; // 第幾頁 
 
  private PageBean pageBean; // 包含分布信息的bean 
 
  private JianSheDWBean jianSheDWBean; 
  // private PageBean page; 
  private JianSheDWService jianSheDWService; 
 
  public int getPage() { 
    return page; 
  } 
 
  public void setPage(int page) { 
    this.page = page; 
  } 
 
  public PageBean getPageBean() { 
    return pageBean; 
  } 
 
  public void setPageBean(PageBean pageBean) { 
    this.pageBean = pageBean; 
  } 
 
  public JianSheDWBean getJianSheDWBean() { 
    return jianSheDWBean; 
  } 
 
  public void setJianSheDWBean(JianSheDWBean jianSheDWBean) { 
    this.jianSheDWBean = jianSheDWBean; 
  } 
 
  public JianSheDWService getJianSheDWService() { 
    return jianSheDWService; 
  } 
 
  public void setJianSheDWService(JianSheDWService jianSheDWService) { 
    this.jianSheDWService = jianSheDWService; 
  } 
 
  @Override   
   public String execute() throws Exception {   
     
   //分頁的pageBean,參數(shù)pageSize表示每頁顯示記錄數(shù),page為當(dāng)前頁   
   this.pageBean = jianSheDWService.queryForPage(10, page);   
   return SUCCESS; 
  } 
} 

在jsp中編寫分頁

<tr class="odd"> 
                          <td> 
                              
                          </td> 
                          <td> 
                            <s:if test="%{pageBean.currentPage == 1}">   
                           首頁   上一頁 
                          </s:if> 
                            <s:else> 
                              <a href="jianguan/getJSDWInfos.action?page=1">首頁</a> 
                              <a 
                                href="jianguan/getJSDWInfos.action?page=<s:property value="%{pageBean.currentPage-1}"/>" />上一頁</a> 
 
                            </s:else> 
                          </td> 
                          <td> 
                            <s:if test="%{pageBean.currentPage != pageBean.totalPage}"> 
 
                              <a 
                                href="jianguan/getJSDWInfos.action?page=<s:property value="%{pageBean.currentPage+1}"/>">下一頁</a> 
                              <a 
                                href="jianguan/getJSDWInfos.action?page=<s:property value="pageBean.totalPage"/>">尾頁 
                              </a> 
                            </s:if> 
                            <s:else>  
                           下一頁 尾頁  
                          </s:else> 
                          </td> 
 
                          <td> 
                            <div align="center"> 
                              頁次 
                              <s:property value="pageBean.currentPage" /> 
                              / 
                              <s:property value="pageBean.totalPage" /> 
                                共 
                              <s:property value="pageBean.allRow" /> 
                              記錄 
                            </div> 
                            <div align="center"></div> 
                          </td> 
                        </tr> 

 上面只是代碼的實(shí)現(xiàn),沒有說明配置文件的配置,讀者根據(jù)情況配置。

希望本文所述對(duì)你有所幫助,SSH2實(shí)現(xiàn)數(shù)據(jù)庫(kù)和界面的分頁內(nèi)容就給大家介紹到這里了。希望大家繼續(xù)關(guān)注我們的網(wǎng)站!想要學(xué)習(xí)java可以繼續(xù)關(guān)注本站。

相關(guān)文章

  • 詳解Spring Boot 部署與服務(wù)配置

    詳解Spring Boot 部署與服務(wù)配置

    本篇文章主要介紹了詳解Spring Boot 部署與服務(wù)配置,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-03-03
  • 解決idea出現(xiàn)的java.lang.OutOfMemoryError:?Java?heap?space的問題

    解決idea出現(xiàn)的java.lang.OutOfMemoryError:?Java?heap?space的問題

    我們?cè)谑褂胕dea的時(shí)候經(jīng)常會(huì)遇到一些問題,本文介紹了如何解決idea出現(xiàn)的java.lang.OutOfMemoryError:?Java?heap?space的問題,文中有相關(guān)的圖文示例,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-06-06
  • SpringBoot Druid配置過程圖解

    SpringBoot Druid配置過程圖解

    這篇文章主要介紹了SpringBoot Druid配置過程圖解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-03-03
  • Java?Stream排序的實(shí)現(xiàn)方式面試精講

    Java?Stream排序的實(shí)現(xiàn)方式面試精講

    這篇文章主要為大家介紹了Java?Stream排序的實(shí)現(xiàn)方式面試精講,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-09-09
  • spring中@Configuration和@Bean注解的用法

    spring中@Configuration和@Bean注解的用法

    這篇文章主要介紹了spring中@Configuration和@Bean注解的用法,@Configuration用于定義配置類,可替換xml配置文件,被注解的類內(nèi)部包含有一個(gè)或多個(gè)被@Bean注解的方法,需要的朋友可以參考下
    2023-05-05
  • 使用Java實(shí)現(xiàn)簡(jiǎn)單搭建內(nèi)網(wǎng)穿透

    使用Java實(shí)現(xiàn)簡(jiǎn)單搭建內(nèi)網(wǎng)穿透

    內(nèi)網(wǎng)穿透是一種網(wǎng)絡(luò)技術(shù),適用于需要遠(yuǎn)程訪問本地部署服務(wù)的場(chǎng)景,本文主要為大家介紹了如何使用Java實(shí)現(xiàn)簡(jiǎn)單搭建內(nèi)網(wǎng)穿透,感興趣的可以了解下
    2024-02-02
  • SpringBoot項(xiàng)目攔截器獲取Post方法的請(qǐng)求body實(shí)現(xiàn)

    SpringBoot項(xiàng)目攔截器獲取Post方法的請(qǐng)求body實(shí)現(xiàn)

    本文主要介紹了SpringBoot項(xiàng)目攔截器獲取Post方法的請(qǐng)求body,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-01-01
  • Java中文件寫入內(nèi)容的幾種常見方法

    Java中文件寫入內(nèi)容的幾種常見方法

    本文主要介紹了Java中文件寫入內(nèi)容的幾種常見方法,主要包括使用NIO的Files工具類、通過commons-io的FileUtils工具類、RandomAccessFile、PrintWriter和BufferedWriter這幾種,具有一定的參考價(jià)值,感興趣的可以了解一下
    2023-10-10
  • Java由淺入深分析多態(tài)的概念

    Java由淺入深分析多態(tài)的概念

    多態(tài)就是指程序中定義的引用變量所指向的具體類型和通過該引用變量發(fā)出的方法調(diào)用在編程時(shí)并不確定,而是在程序運(yùn)行期間才確定,即一個(gè)引用變量到底會(huì)指向哪個(gè)類的實(shí)例對(duì)象,該引用變量發(fā)出的方法調(diào)用到底是哪個(gè)類中實(shí)現(xiàn)的方法,必須在由程序運(yùn)行期間才能決定
    2022-04-04
  • Java并發(fā)編程系列之LockSupport的用法

    Java并發(fā)編程系列之LockSupport的用法

    這篇文章主要為大家介紹了Java LockSupport的用法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助,希望能夠給你帶來幫助
    2021-11-11

最新評(píng)論