springmvc mybatis怎么实现分页查询

 我来答
皞游窄悉
2017-10-30 · 超过17用户采纳过TA的回答
知道答主
回答量:27
采纳率:0%
帮助的人:27.2万
展开全部
1.封装分页Page类  package com.framework.common.page.impl;    import java.io.Serializable;    import com.framework.common.page.IPage;  /**  *  *  *  */  public abstract class BasePage implements IPage, Serializable {    /**  *  */  private static final long serialVersionUID = -3623448612757790359L;    public static int DEFAULT_PAGE_SIZE = 20;  private int pageSize = DEFAULT_PAGE_SIZE;  private int currentResult;  private int totalPage;  private int currentPage = 1;  private int totalCount = -1;    public BasePage(int currentPage, int pageSize, int totalCount) {  this.currentPage = currentPage;  this.pageSize = pageSize;  this.totalCount = totalCount;  }    public int getTotalCount() {  return this.totalCount;  }    public void setTotalCount(int totalCount) {  if (totalCount = getTotalPage();  }    public int getNextPage() {  if (isLastPage()) {  return this.currentPage;  }  return this.currentPage + 1;  }    public int getCurrentResult() {  this.currentResult = ((getPageNo() - 1) * getPageSize());  if (this.currentResult data;    public Page() {  }    public Page(int currentPage, int pageSize, int totalCount) {  super(currentPage, pageSize, totalCount);  }    public Page(int currentPage, int pageSize, int totalCount, List data) {  super(currentPage, pageSize, totalCount);  this.data = data;  }    public List getData() {  return data;  }    public void setData(List data) {  this.data = data;  }      }    2.封装分页插件  package com.framework.common.page.plugin;    import java.sql.Connection;  import java.sql.PreparedStatement;  import java.sql.ResultSet;  import java.sql.SQLException;  import java.util.List;  import java.util.Properties;    import javax.xml.bind.PropertyException;    import org.apache.commons.lang3.StringUtils;  import org.apache.ibatis.executor.ErrorContext;  import org.apache.ibatis.executor.ExecutorException;  import org.apache.ibatis.executor.statement.BaseStatementHandler;  import org.apache.ibatis.executor.statement.RoutingStatementHandler;  import org.apache.ibatis.mapping.BoundSql;  import org.apache.ibatis.mapping.MappedStatement;  import org.apache.ibatis.mapping.ParameterMapping;  import org.apache.ibatis.mapping.ParameterMode;  import org.apache.ibatis.plugin.Interceptor;  import org.apache.ibatis.plugin.Intercepts;  import org.apache.ibatis.plugin.Invocation;  import org.apache.ibatis.plugin.Plugin;  import org.apache.ibatis.reflection.MetaObject;  import org.apache.ibatis.reflection.property.PropertyTokenizer;  import org.apache.ibatis.scripting.xmltags.ForEachSqlNode;  import org.apache.ibatis.session.Configuration;  import org.apache.ibatis.type.TypeHandler;  import org.apache.ibatis.type.TypeHandlerRegistry;    import com.framework.common.page.impl.Page;  import com.framework.common.utils.ReflectUtil;  /**  *  *  *  */  @Intercepts({ @org.apache.ibatis.plugin.Signature(type = org.apache.ibatis.executor.statement.StatementHandler.class, method = "prepare", args = { Connection.class }) })  public class PagePlugin implements Interceptor {    private String dialect = "";  private String pageSqlId = "";    @Override  public Object intercept(Invocation invocation) throws Throwable {  if (invocation.getTarget() instanceof RoutingStatementHandler) {  BaseStatementHandler delegate = (BaseStatementHandler) ReflectUtil  .getValueByFieldName(  (RoutingStatementHandler) invocation.getTarget(),  "delegate");  MappedStatement mappedStatement = (MappedStatement) ReflectUtil  .getValueByFieldName(delegate,  "mappedStatement");    Page page = Page.threadLocal.get();  if (page == null) {  page = new Page();  Page.threadLocal.set(page);  }    if (mappedStatement.getId().matches(".*(" + this.pageSqlId + ")$") && page.getPageSize() > 0) {  BoundSql boundSql = delegate.getBoundSql();  Object parameterObject = boundSql.getParameterObject();    String sql = boundSql.getSql();  String countSqlId = mappedStatement.getId().replaceAll(pageSqlId, "Count");  MappedStatement countMappedStatement = null;  if (mappedStatement.getConfiguration().hasStatement(countSqlId)) {  countMappedStatement = mappedStatement.getConfiguration().getMappedStatement(countSqlId);  }  String countSql = null;  if (countMappedStatement != null) {  countSql = countMappedStatement.getBoundSql(parameterObject).getSql();  } else {  countSql = "SELECT COUNT(1) FROM (" + sql + ") T_COUNT";  }    int totalCount = 0;  PreparedStatement countStmt = null;  ResultSet resultSet = null;  try {  Connection connection = (Connection) invocation.getArgs()[0];  countStmt = connection.prepareStatement(countSql);  BoundSql countBoundSql = new BoundSql(mappedStatement.getConfiguration(), countSql, boundSql.getParameterMappings(), parameterObject);    setParameters(countStmt, mappedStatement, countBoundSql, parameterObject);    resultSet = countStmt.executeQuery();  if(resultSet.next()) {  totalCount = resultSet.getInt(1);  }  } catch (Exception e) {  throw e;  } finally {  try {  if (resultSet != null) {  resultSet.close();  }  } finally {  if (countStmt != null) {  countStmt.close();  }  }  }    page.setTotalCount(totalCount);    ReflectUtil.setValueByFieldName(boundSql, "sql", generatePageSql(sql,page));  }  }    return invocation.proceed();  }      /**  * 对SQL参数(?)设值,参考org.apache.ibatis.executor.parameter.DefaultParameterHandler  * @param ps  * @param mappedStatement  * @param boundSql  * @param parameterObject  * @throws SQLException  */  private void setParameters(PreparedStatement ps,MappedStatement mappedStatement,BoundSql boundSql,Object parameterObject) throws SQLException {  ErrorContext.instance().activity("setting parameters").object(mappedStatement.getParameterMap().getId());  List parameterMappings = boundSql.getParameterMappings();  if (parameterMappings != null) {  Configuration configuration = mappedStatement.getConfiguration();  TypeHandlerRegistry typeHandlerRegistry = configuration.getTypeHandlerRegistry();  MetaObject metaObject = parameterObject == null ? null: configuration.newMetaObject(parameterObject);  for (int i = 0; i ");  pageSql.append(page.getCurrentResult());  }  return pageSql.toString();  }else{  return sql;  }  }    @Override  public Object plugin(Object target) {  return Plugin.wrap(target, this);  }    @Override  public void setProperties(Properties properties) {  try {  if (StringUtils.isEmpty(this.dialect = properties  .getProperty("dialect"))) {  throw new PropertyException("dialect property is not found!");  }  if (StringUtils.isEmpty(this.pageSqlId = properties  .getProperty("pageSqlId"))) {  throw new PropertyException("pageSqlId property is not found!");  }  } catch (PropertyException e) {  e.printStackTrace();  }  }    }附上出处链接:71829.htmspringmvc mybatis怎么实现分页查询
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式