基于Spring JdbcTemplate 的分页处理

3 篇文章 0 订阅

1.JdbcPaginationHelper.java

import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.List;

import org.springframework.dao.DataAccessException;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.jdbc.core.ResultSetExtractor;
import org.springframework.jdbc.core.simple.ParameterizedRowMapper;
import org.tshark.core.orm.Page;

public class JdbcPaginationHelper<T> {
	private static final int DEFAULT_PAGE_SIZE = 30;

	public Page<T> fetchPage(final JdbcTemplate jdbcTemplate, final String countSql, final String dataSql, final Object args[],
			final int pageNo, final ParameterizedRowMapper<T> rowMapper) {
		return fetchPage(jdbcTemplate, countSql, dataSql, args, pageNo, DEFAULT_PAGE_SIZE, rowMapper);
	}

	public Page<T> fetchPage(final JdbcTemplate jdbcTemplate, final String countSql, final String dataSql, final Object args[],
			final int pageNo, final int pageSize, final ParameterizedRowMapper<T> rowMapper) {
		// 总记录数据
		final int rowCount = jdbcTemplate.queryForInt(countSql, args);
		// 计算总页数
		int pageCount = rowCount / pageSize;
		if (rowCount > pageSize * pageCount) {
			pageCount++;
		}
		final Page<T> page = new Page<T>();
		page.setPageNo(pageNo);
		page.setTotalCount(pageCount);
		page.setPageSize(pageSize);
		// 根据pageNo取一页数据
		final int startRow = (pageNo - 1) * pageSize;
		jdbcTemplate.query(dataSql, args, new ResultSetExtractor<Page<T>>() {
			public Page<T> extractData(ResultSet rs) throws SQLException, DataAccessException {
				final List<T> pageItems = page.getResult();
				int currentRow = 0;
				while (rs.next() && currentRow < startRow + pageSize) {
					if (currentRow >= startRow) {
						pageItems.add(rowMapper.mapRow(rs, currentRow));
					}
					currentRow++;
				}
				return page;
			}
		});
		return page;
	}
}


2.Page.java

import java.util.List;

import org.apache.commons.lang.StringUtils;

import com.google.common.collect.Lists;

/**
 * @param <T> Page中记录的类型.
 */
public class Page<T> {
	//-- 公共变量 --//
	public static final String ASC = "asc";
	public static final String DESC = "desc";

	//-- 分页参数 --//
	protected int pageNo = 1;
	protected int pageSize = 1;
	protected String orderBy = null;
	protected String order = null;
	protected boolean autoCount = true;

	protected List<T> result = Lists.newArrayList();
	protected long totalCount = -1;

	public Page() {
	}

	public Page(int pageSize) {
		this.pageSize = pageSize;
	}
	/**
	 * 获得当前页的页号,序号从1开始,默认为1.
	 */
	public int getPageNo() {
		return pageNo;
	}

	/**
	 * 设置当前页的页号,序号从1开始,低于1时自动调整为1.
	 */
	public void setPageNo(final int pageNo) {
		this.pageNo = pageNo;

		if (pageNo < 1) {
			this.pageNo = 1;
		}
	}

	public Page<T> pageNo(final int thePageNo) {
		setPageNo(thePageNo);
		return this;
	}

	/**
	 * 获得每页的记录数量,默认为1.
	 */
	public int getPageSize() {
		return pageSize;
	}

	/**
	 * 设置每页的记录数量,低于1时自动调整为1.
	 */
	public void setPageSize(final int pageSize) {
		this.pageSize = pageSize;

		if (pageSize < 1) {
			this.pageSize = 1;
		}
	}

	public Page<T> pageSize(final int thePageSize) {
		setPageSize(thePageSize);
		return this;
	}

	/**
	 * 根据pageNo和pageSize计算当前页第一条记录在总结果集中的位置,序号从1开始.
	 */
	public int getFirst() {
		return ((pageNo - 1) * pageSize) + 1;
	}

	/**
	 * 获得排序字段,无默认值.多个排序字段时用','分隔.
	 */
	public String getOrderBy() {
		return orderBy;
	}

	/**
	 * 设置排序字段,多个排序字段时用','分隔.
	 */
	public void setOrderBy(final String orderBy) {
		this.orderBy = orderBy;
	}

	public Page<T> orderBy(final String theOrderBy) {
		setOrderBy(theOrderBy);
		return this;
	}

	/**
	 * 获得排序方向.
	 */
	public String getOrder() {
		return order;
	}

	/**
	 * 设置排序方式向.
	 *
	 * @param order 可选值为desc或asc,多个排序字段时用','分隔.
	 */
	public void setOrder(final String order) {
		//检查order字符串的合法值
		String[] orders = StringUtils.split(StringUtils.lowerCase(order), ',');
		if(orders != null){
			for (String orderStr : orders) {
				if (!StringUtils.equals(DESC, orderStr) && !StringUtils.equals(ASC, orderStr)) {
					throw new IllegalArgumentException("排序方向" + orderStr + "不是合法值");
				}
			}
		}

		this.order = StringUtils.lowerCase(order);
	}

	public Page<T> order(final String theOrder) {
		setOrder(theOrder);
		return this;
	}

	/**
	 * 是否已设置排序字段,无默认值.
	 */
	public boolean isOrderBySetted() {
		return (StringUtils.isNotBlank(orderBy) && StringUtils.isNotBlank(order));
	}

	/**
	 * 查询对象时是否自动另外执行count查询获取总记录数, 默认为false.
	 */
	public boolean isAutoCount() {
		return autoCount;
	}

	/**
	 * 查询对象时是否自动另外执行count查询获取总记录数.
	 */
	public void setAutoCount(final boolean autoCount) {
		this.autoCount = autoCount;
	}

	public Page<T> autoCount(final boolean theAutoCount) {
		setAutoCount(theAutoCount);
		return this;
	}

	//-- 访问查询结果函数 --//

	/**
	 * 取得页内的记录列表.
	 */
	public List<T> getResult() {
		return result;
	}

	/**
	 * 设置页内的记录列表.
	 */
	public void setResult(final List<T> result) {
		this.result = result;
	}

	/**
	 * 取得总记录数, 默认值为-1.
	 */
	public long getTotalCount() {
		return totalCount;
	}

	/**
	 * 设置总记录数.
	 */
	public void setTotalCount(final long totalCount) {
		this.totalCount = totalCount;
	}

	/**
	 * 根据pageSize与totalCount计算总页数, 默认值为-1.
	 */
	public long getTotalPages() {
		if (totalCount < 0) {
			return -1;
		}

		long count = totalCount / pageSize;
		if (totalCount % pageSize > 0) {
			count++;
		}
		return count;
	}

	/**
	 * 是否还有下一页.
	 */
	public boolean isHasNext() {
		return (pageNo + 1 <= getTotalPages());
	}

	/**
	 * 取得下页的页号, 序号从1开始.
	 * 当前页为尾页时仍返回尾页序号.
	 */
	public int getNextPage() {
		if (isHasNext()) {
			return pageNo + 1;
		} else {
			return pageNo;
		}
	}

	/**
	 * 是否还有上一页.
	 */
	public boolean isHasPre() {
		return (pageNo - 1 >= 1);
	}

	/**
	 * 取得上页的页号, 序号从1开始.
	 * 当前页为首页时返回首页序号.
	 */
	public int getPrePage() {
		if (isHasPre()) {
			return pageNo - 1;
		} else {
			return pageNo;
		}
	}
}

3.TransactionJdbcService.java

import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;

import org.springframework.jdbc.core.PreparedStatementSetter;
import org.springframework.jdbc.core.simple.ParameterizedRowMapper;
import org.springframework.stereotype.Service;
import org.tshark.core.orm.Page;
import org.tshark.core.service.AbstractJdbcService;
import org.tshark.core.service.JdbcPaginationHelper;
import org.tshark.framework.model.TransactionModel;

@Service
public class TransactionJdbcService extends AbstractJdbcService {
	private static String QUERY_TRANS_COUNT_SQL = "select count(*) from sys_transaction  ";
	private static String QUERY_TRANS_DATA_SQL = "select * from sys_transaction ";
	private static String INSERT_TRANS_SQL = "insert into `sys_transaction` (`amount`,`month`,`region`) values(?,?,?) ";
	@Transient
	protected JdbcTemplate jdbcTemplate;


	@Resource
	public void setDataSource(DataSource dataSource) {
		jdbcTemplate = new JdbcTemplate(dataSource);
	}
	public void insertTransaction(final TransactionModel transaction) {
		jdbcTemplate.update(INSERT_TRANS_SQL, new PreparedStatementSetter() {
			@Override
			public void setValues(PreparedStatement ps) throws SQLException {
				ps.setDouble(1, transaction.getAmount());
				ps.setInt(2, transaction.getMonth());
				ps.setString(3, transaction.getRegion());
			}
		});
	}

	public Page<TransactionModel> findTransactionList(int pageNo, int month) {
		Object[] args = null;
		if (month != 0) {
			QUERY_TRANS_COUNT_SQL += "where month=?";
			QUERY_TRANS_DATA_SQL += "where month=?";
			args = new Object[] { month };
		}
		JdbcPaginationHelper<TransactionModel> JdbcPaginationHelper = new JdbcPaginationHelper<TransactionModel>();
		return JdbcPaginationHelper.fetchPage(jdbcTemplate, QUERY_TRANS_COUNT_SQL, QUERY_TRANS_DATA_SQL, args, pageNo,
				new TransactionRowMap());
	}

	class TransactionRowMap implements ParameterizedRowMapper<TransactionModel> {

		@Override
		public TransactionModel mapRow(ResultSet rs, int rowNum) throws SQLException {
			TransactionModel transaction = new TransactionModel();
			transaction.setId(rs.getLong("id"));
			transaction.setAmount(rs.getDouble("amount"));
			transaction.setMonth(rs.getInt("month"));
			transaction.setRegion(rs.getString("region"));
			return transaction;
		}

	}
}



  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
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执行该查询,并将结果集转化为一个列表返回。 这就是使用JdbcTemplateSpring中进行SQL Server2008分页查询的基本步骤。希望这可以帮助到你。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值