JdbcTemplate + sqlserver 2005 分页+Extjs

JdbcTemplate + sqlserver 2005 分页+Extjs

package com.ur.util;

import java.util.List;
import java.util.Map;

import org.springframework.jdbc.core.JdbcTemplate;

public class Pagination  {
    public static final int NUMBERS_PER_PAGE = 20;
    private int offset = 0;
    private int limit = 20;
    private int totalSize;
    private List<Map<String, Object>> resultList;
    private JdbcTemplate jTemplate;

    public Pagination() {

    }
    public Pagination(String sql, int offset, int limit,JdbcTemplate jTemplate){
        setOffset(offset);
        setLimit(limit);
        setjTemplate(jTemplate);
        int orderByIndex = sql.toLowerCase().lastIndexOf("order by");  
        if (orderByIndex <= 0) {  
          throw new UnsupportedOperationException(  
              "must specify 'order by' statement to support limit operation with offset in sql server 2005");  
        }  
        String totalSql = "select count(*) as totalsize from ("+sql.toLowerCase().substring(0, orderByIndex) +") totalTable ";

        setTotalSize(this.jTemplate.queryForInt(totalSql));
        String sqls = this.getLimitString(sql, offset, limit);
        setResultList(this.jTemplate.queryForList(sqls));
    }
    public String getLimitString(String sql, int offset, int limit) { 
        return getLimitString(sql, offset > 0,offset,limit);  
    }  

    public String getLimitString(String sql, boolean hasOffset, int offset, int limit) {
        int orderByIndex = sql.toLowerCase().lastIndexOf("order by");  
        if (orderByIndex <= 0) {  
          throw new UnsupportedOperationException(  
              "must specify 'order by' statement to support limit operation with offset in sql server 2005");  
        } 

        String sqlOrderBy = sql.substring(orderByIndex + 8);  
        String sqlRemoveOrderBy = sql.substring(0, orderByIndex);  
        int insertPoint = getSqlAfterSelectInsertPoint(sql);  
        StringBuilder sbSql =  new StringBuilder(sql.length() + 100).append("with tempPagination as(").append(sqlRemoveOrderBy).insert(  
            insertPoint + 23, " ROW_NUMBER() OVER(ORDER BY " + sqlOrderBy + ") as RowNumber,").append(  
            ") select * from tempPagination ");
        if(offset != -1  && limit !=-1){
            sbSql.append("  where RowNumber between "+(offset+1)+" and "+(offset+limit)+"") ;
        }
       return sbSql.toString();  
      }  


     private static int getSqlAfterSelectInsertPoint(String sql) {  
        int selectIndex = sql.toLowerCase().indexOf("select");  
        final int selectDistinctIndex = sql.toLowerCase().indexOf("select distinct");  
        return selectIndex + (selectDistinctIndex == selectIndex ? 15 : 6);  
     }
    public int getOffset() {
        return offset;
    }
    public void setOffset(int offset) {
        this.offset = offset;
    }
    public int getLimit() {
        return limit;
    }
    public void setLimit(int limit) {
        this.limit = limit;
    }
    public int getTotalSize() {
        return totalSize;
    }
    public void setTotalSize(int totalSize) {
        this.totalSize = totalSize;
    }
    public List<Map<String, Object>> getResultList() {
        return resultList;
    }
    public void setResultList(List<Map<String, Object>> resultList) {
        this.resultList = resultList;
    }
    public JdbcTemplate getjTemplate() {
        return jTemplate;
    }
    public void setjTemplate(JdbcTemplate jTemplate) {
        this.jTemplate = jTemplate;
    }
}

业务调用 Pagination pagination = new Pagination(sqlSb.toString(),start,limit,this.jdbcTemplate);

在Spring中使用JdbcTemplate进行SQL Server2008的分页查询是非常简单的。 首先,我们需要确保已经配置了适当的数据源,并且已经将JdbcTemplate注入到我们的代码中。 然后,我们可以使用JdbcTemplate的`query`方法来执行带有分页功能的SQL查询。具体来说,我们可以通过传递一个`PreparedStatementCreator`对象来执行SQL查询,并使用`ResultSetExtractor`来处理返回的结果集。在这里,我们可以使用SQL Server的`ROW_NUMBER()`函数来获取每行的行号。 下面是一个示例代码片段,展示了如何使用JdbcTemplate进行分页查询: ```java import org.springframework.jdbc.core.JdbcTemplate; import org.springframework.jdbc.core.PreparedStatementCreator; import org.springframework.jdbc.core.ResultSetExtractor; import java.sql.Connection; import java.sql.PreparedStatement; import java.sql.SQLException; import java.sql.ResultSet; public class PaginationExample { private JdbcTemplate jdbcTemplate; public List<User> getUsersByPage(int pageNumber, int pageSize) { int offset = (pageNumber - 1) * pageSize; String sql = "SELECT ROW_NUMBER() OVER (ORDER BY ID) AS RowNum, * FROM Users"; sql += "WHERE RowNum BETWEEN " + offset + " AND " + (offset + pageSize); return jdbcTemplate.query(new PreparedStatementCreator() { @Override public PreparedStatement createPreparedStatement(Connection connection) throws SQLException { return connection.prepareStatement(sql); } }, new ResultSetExtractor<List<User>>() { @Override public List<User> extractData(ResultSet rs) throws SQLException { List<User> userList = new ArrayList<>(); while (rs.next()) { // 从结果集中提取数据并添加到userList中 userList.add(new User(rs.getInt("ID"), rs.getString("Name"), rs.getString("Email"))); } return userList; } }); } } ``` 在上面的示例中,我们可以看到`getUsersByPage`方法接收分页的页号和页面大小作为参数。它首先计算偏移量(即从结果集中的哪个行开始返回),然后构建了一条使用`ROW_NUMBER()`函数进行行号分配和过滤的SQL查询。最后,我们使用JdbcTemplate执行该查询,并将结果集转化为一个列表返回。 这就是使用JdbcTemplate在Spring中进行SQL Server2008分页查询的基本步骤。希望这可以帮助到你。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值