`

spring分页汇总

 
阅读更多

      用Spring的JdbcTemplate实现分页功能
最近使用了spring中的JdbcTemplate实现数据库的查询和插入操作,发现spring的JdbcTemplate 不象HibernateTemplate那么好,已经实现了分页功能。所以要自己实现,使用 getJdbcTemplate().queryForList(string sql)得到的结果集是所有的。

      如果你的查询有10000条记录,或者更多,速度肯定慢了,当然你可以通过resultset中的游标控制查询的起始和结束。我这里用的是Oracle数据库,使用伪列ROWNUM来实现分页。我的分页代码如下:
  
  

     package com.deity.ranking.util;import java.util.List;
  import org.springframework.jdbc.core.JdbcTemplate;
  import org.springframework.jdbc.core.support.JdbcDaoSupport;
  /** * 分页函数 * * @author allenpan */public class Pagination extends JdbcDaoSupport{
  public static final int NUMBERS_PER_PAGE = 10;
  //一页显示的记录数
  private int numPerPage;
  //记录总数
  private int totalRows;
  //总页数
  private int totalPages;
  //当前页码
  private int currentPage;
  //起始行数
  private int startIndex;
  //结束行数
  private int lastIndex;
  //结果集存放List
  private List resultList;
  //JdbcTemplate jTemplate
  private JdbcTemplate jTemplate;
  /**
  * 每页显示10条记录的构造函数,使用该函数必须先给Pagination设置currentPage,jTemplate初值
  * @param sql oracle语句
  */
  public Pagination(String sql){
  if(jTemplate == null){
  throw new IllegalArgumentException("com.deity.ranking.util.Pagination.jTemplate is null,please initial it first. ");
  }else if(sql.equals("")){
  throw new IllegalArgumentException("com.deity.ranking.util.Pagination.sql is empty,please initial it first. ");
  }
  new Pagination(sql,currentPage,NUMBERS_PER_PAGE,jTemplate);
  }
  /**分页构造函数
  * @param sql 根据传入的sql语句得到一些基本分页信息
  * @param currentPage 当前页
  * @param numPerPage 每页记录数
  * @param jTemplate JdbcTemplate实例
  */
  public Pagination(String sql,int currentPage,int numPerPage,JdbcTemplate jTemplate){
  if(jTemplate == null){
  throw new IllegalArgumentException("com.deity.ranking.util.Pagination.jTemplate is null,please initial it first. ");
  }else if(sql == null || sql.equals("")){
  throw new IllegalArgumentException("com.deity.ranking.util.Pagination.sql is empty,please initial it first. ");
  }
  //设置每页显示记录数
  setNumPerPage(numPerPage);
  //设置要显示的页数
  setCurrentPage(currentPage);
  //计算总记录数
  StringBuffer totalSQL = new StringBuffer(" SELECT count(*) FROM ( ");
  totalSQL.append(sql);
  totalSQL.append(" ) totalTable ");
  //给JdbcTemplate赋值
  setJdbcTemplate(jTemplate);
  //总记录数
  setTotalRows(getJdbcTemplate().queryForInt(totalSQL.toString()));
  //计算总页数
  setTotalPages();
  //计算起始行数
  setStartIndex();
  //计算结束行数
  setLastIndex();
  System.out.println("lastIndex="+lastIndex);//////////////////
  //构造oracle数据库的分页语句
  StringBuffer paginationSQL = new StringBuffer(" SELECT * FROM ( ");
  paginationSQL.append(" SELECT temp.* ,ROWNUM num FROM ( ");
  paginationSQL.append(sql);
  paginationSQL.append(" ) temp where ROWNUM <= " + lastIndex);
  paginationSQL.append(" ) WHERE num > " + startIndex);
  //装入结果集
  setResultList(getJdbcTemplate().queryForList(paginationSQL.toString()));
  }
  /**
  * @param args
  */
  public static void main(String[] args) {
  // TODO Auto-generated method stub    }
  public int getCurrentPage() {
  return currentPage;
  }
  public void setCurrentPage(int currentPage) {
  this.currentPage = currentPage;
  }
  public int getNumPerPage() {
  return numPerPage;
  }
  public void setNumPerPage(int numPerPage) {
  this.numPerPage = numPerPage;
  }
  public List getResultList() {
  return resultList;    }
  public void setResultList(List resultList) {
  this.resultList = resultList;
  }
  public int getTotalPages() {
  return totalPages;
  }
  //计算总页数
  public void setTotalPages() {
  if(totalRows % numPerPage == 0){
  this.totalPages = totalRows / numPerPage;
  }else{
  this.totalPages = (totalRows / numPerPage) + 1;
  }
  }
  public int getTotalRows() {
  return totalRows;
  }
  public void setTotalRows(int totalRows) {
  this.totalRows = totalRows;
  }
  public int getStartIndex() {
  return startIndex;
  }
  public void setStartIndex() {
  this.startIndex = (currentPage - 1) * numPerPage;
  }
  public int getLastIndex() {
  return lastIndex;
  }
  public JdbcTemplate getJTemplate() {
  return jTemplate;
  }
  public void setJTemplate(JdbcTemplate template) {
  jTemplate = template;
  }
  //计算结束时候的索引
  public void setLastIndex() {
  System.out.println("totalRows="+totalRows);///////////
  System.out.println("numPerPage="+numPerPage);///////////
  if( totalRows < numPerPage){
  this.lastIndex = totalRows;
  }else if((totalRows % numPerPage == 0) || (totalRows % numPerPage != 0 && currentPage < totalPages)){
  this.lastIndex = currentPage * numPerPage;
  }else if(totalRows % numPerPage != 0 && currentPage == totalPages){//最后一页
  this.lastIndex = totalRows ;
  }
  }}在我的业务逻辑代码中:
  /**
  * find season ranking list from DC
  * @param areaId 选手区域id
  * @param rankDate 赛季
  * @param category 类别
  * @param characterName 角色名
  * @return List
  */
  public List findSeasonRankingList(Long areaId, int rankYear,int rankMonth,
  Long categoryId,String characterName) {
  //SQL语句
   StringBuffer sql = new StringBuffer(" SELECT C.USERID userid,D.POSNAME posname,C.GAMEID gameid,C.AMOUNT amount,C.RANK rank FROM ");
  //表            sql.append(" (SELECT B.USERID USERID,");
  sql.append(" B.POSID POSID,");
  sql.append(" A.DISTRICT_CODE DISTRICTCODE,");
  sql.append(" A.GAMEID GAMEID,");
  sql.append(" AMOUNT AMOUNT,");
  sql.append(" RANK RANK ");
  sql.append(" FROM TB_FS_RANK A ");
  sql.append(" LEFT JOIN TB_CHARACTER_INFO B ");
  sql.append(" ON A.DISTRICT_CODE = B.DISTRICT_CODE ");
  sql.append(" AND A.GAMEID = B.GAMEID ");
  //附加条件
  if(areaId != null && areaId.intValue() != 0){
  sql.append(" and A.DISTRICT_CODE = " + areaId.intValue());
  }
  if( rankYear > 1970 && rankMonth > 0){
  //hql.append(" and sas.id.dt >= to_date('" + rankYear + "-" + rankMonth + "-01 00:00:00'," + "YYYY-MM-DD HH24:MI:SS");
   //hql.append(" and sas.id.dt <= to_date('" + rankYear + "-" + rankMonth + "-" + TimeTool.findMaxDateInMonth(rankYear,rankMonth) + " 23:59:59'," + "YYYY-MM-DD HH24:MI:SS");
  sql.append(" and A.DT = fn_time_convert(to_date('" + rankYear + "-" + rankMonth + "'," + "'YYYY-MM')) ");
  }
  if(categoryId != null && categoryId.intValue() != 0){
  sql.append(" and A.CID = " + categoryId.intValue());
  }
  if(characterName != null && !characterName.trim().equals("")){
  sql.append(" and A.GAMEID = '" + characterName.trim()+"' ");
  }
  sql.append(" ORDER BY RANK ASC) C ");
  sql.append(" LEFT JOIN TB_FS_POSITION D ");
  sql.append(" ON C.POSID = D.POSID ");
  sql.append(" ORDER BY C.RANK ");
  System.out.println("hql="+sql.toString());////////////////
  //使用自己的分页程序控制结果集
  Pagination pageInfo = new Pagination(sql.toString(),1,10,getJdbcTemplate());
  return pageInfo.getResultList();
  //return getJdbcTemplate().queryForList(sql.toString());
  } 

非常简单但有使用的分页条件判断语句。
if ($page <= 1) {
            $page_str .= "[首页][上一页]";
        } else {
            $page_str .= "[<a href=$PHP_SELF?module=$module&page=1>首页</a>][<a href=$PHP_SELF?module=$module&page=".($page-1).">上一页</a>]";
        }
        if ($page >= $page_total) {
            $page_str .= "[下一页][尾页]";
        } else {
            $page_str .= "[<a href=$PHP_SELF?module=$module&page=".($page+1).">下一页</a>][<a href=$PHP_SELF?module=$module&page=$page_total>尾页</a>]";
        }

 

分享到:
评论

相关推荐

    java分页技术汇总

    本资料汇总了多种Java分页技术,涵盖了Struts框架下的实现方式,对于Java Web开发者来说极具参考价值。 1. **JSP分页**: JSP可以通过内置的`&lt;c:forEach&gt;`标签配合`pageContext`对象进行简单的分页。`pageContext`...

    java分页汇总技术文档下载

    4. Spring Data JPA 分页 Spring Data JPA扩展了JPA,提供了更强大的查询功能。可以利用`Pageable`和`Page`,配合`JpaRepository`或`PagingAndSortingRepository`接口进行分页查询。 ```java Page&lt;YourEntity&gt; page...

    SpringBlade开发手册.pdf

    - **分页处理**:对于大数据量场景,分页是非常重要的,SpringBlade提供了简单易用的分页实现方法。 - **微服务远程调用**:通过声明式服务调用Feign等方式,实现微服务之间的远程调用。 - **熔断机制**:使用...

    java之hibernate和spring技术难点及其要点总结

    - **分页查询**:对查询结果进行分页处理。 3. **`createSQLQuery` 的用法**:该方法允许开发者直接执行原生SQL语句,同时提供了一种灵活的方式来映射查询结果到Java对象。 4. **HQL返回结果类型**:HQL支持多种...

    在Spring JPA中汇总来自多个表的数据的正确方法

    在Spring JPA(Java Persistence API)中,当需要从多个关联表中汇总数据时,我们需要有效地利用JOIN查询、Repository接口和Projection。以下是如何正确处理这种场景的详细步骤和相关知识点: 1. **实体关系映射**...

    sqltoy-orm是比hibernate+myBatis(plus)更加贴合项目的orm框架(依赖spring)

    Java真正智慧的ORM框架,除具有JPA功能外,具有最佳的sql编写模式、独创的缓存翻译、最优化的分页、并提供分组汇总、同比环比、行列转换、树形排序汇总、多数据库适配(oracle\mysql\sqlserver\postgresql\sqlite\db2...

    SSH经典面试题汇总

    根据给定文件的信息,我们可以总结出以下关于Struts、Hibernate、Spring的经典面试题知识点: ### 一、Java集合框架 Java集合框架主要包括`Collection`和`Map`两大类。 - **Collection**: 包括`List`和`Set`两种...

    2016面试汇总.doc

    【面试汇总】文档包含了2016年面试中的一些常见问题,主要涵盖了Java编程、Spring框架、多线程、集合框架、数据库、设计模式以及面向切面编程等多个方面的知识点。 1. **抽象类与接口的区别**: 抽象类是类的一个...

    八股文知识点汇总——各互联网大厂java工程师面试题.pdf

    【标题】和【描述】提及的是一个针对Java工程师面试的综合知识汇总,特别是关于八股文面试题,其中包含了MyBatis、ZooKeeper、Redis、Java并发编程、Spring框架等多个技术领域的题目。这些题目旨在考察候选人在实际...

    动吧模拟面试知识点汇总.pdf

    以下是对文档内容的知识点汇总: 1. 分页技术实现:面试中常询问如何实现分页功能,分页技术是Web应用中处理大量数据展示的常用手段,面试者通常被问及在项目中使用的分页技术和具体场景。 2. 日志模块:涉及日志...

    医院信息系统(临床诊疗、药品管理、财务管理、患者管理)

    诊疗活动由各工作站配合完成,并将临床信息进行整理、处理、汇总、统计、分析等。本系统包括以下工作站:门诊医生工作站、药房医生工作站、医技医生工作站、收费员工作站、对帐员工作站、管理员工作站。基于Spring ...

    复习资料汇总:包括mybatis-plus spingboot等

    SpringBoot是由Pivotal团队提供的全新框架,旨在简化Spring应用的初始搭建以及开发过程。它的关键特性包括: - **快速启动**:通过"起步依赖"(Starter POMs),SpringBoot能快速创建可执行的jar,内置Tomcat或其他...

    北京Java程序员面试汇总.doc

    ### 北京Java程序员面试汇总知识点解析 #### 一、自我介绍及来京原因 - **个人信息**: 面试者需要简要介绍自己的姓名、毕业院校、工作经历等基本信息。 - **工作经验**: 强调在深圳的工作经历,包括参与过的项目...

    单点登录源码

    PageHelper | MyBatis物理分页插件 | [http://git.oschina.net/free/Mybatis_PageHelper](http://git.oschina.net/free/Mybatis_PageHelper) Druid | 数据库连接池 | [https://github.com/alibaba/druid]...

    Java架构面试专题汇总(含答案)和学习笔记

    Java架构面试专题汇总,是Java开发者在求职或者晋升过程中必须面对的重要环节。这份资源包含了详细的面试问题和答案,以及相关的学习笔记,旨在帮助Java工程师更好地准备面试,提升自身的技术素养。下面,我们将深入...

    BIRT开发手册

    - **分页、页眉与页脚**:控制报表的分页显示、打印设置及页眉页脚信息。 - **隔行高亮度显示**:增强报表的可读性。 - **数据绑定**:将数据与报表元素关联起来。 #### 五、BIRT报表Script - **JavaScript脚本...

    ssm 开发教师综合评价系统

    "报表显示"则涉及数据的汇总和分析,可能是以图表、表格等形式展示教师的总体评价、平均分等信息。这可能需要使用到数据分析和可视化工具,如JFreeChart或者ECharts,帮助管理者快速理解教师的绩效状况。 "批量导入...

    支付宝面试汇总(最新最全)

    6. Oracle分页查询可使用ROWNUM配合子查询或游标实现,例如SELECT * FROM (SELECT T.*, ROWNUM RN FROM (SELECT ...) T WHERE ROWNUM ) WHERE RN &gt; offset。 7. 数据库优化包括索引优化、SQL优化、表结构优化、硬件...

    八股文知识点汇总-各互联网大厂java工程师面试题.pdf

    全自动化 ORM 框架如 Hibernate 有何区别?...此外,对于一个全面的 Java 工程师面试,还会考察 JVM 内存模型、多线程、数据库设计、Spring 框架、分布式服务、网络协议、数据结构与算法、设计模式等方面的知识。

Global site tag (gtag.js) - Google Analytics