使用Mybatis进行分页时需要注意哪些事项-创新互联

使用Mybatis进行分页时需要注意哪些事项?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。

创新互联公司服务项目包括青山湖网站建设、青山湖网站制作、青山湖网页制作以及青山湖网络营销策划等。多年来,我们专注于互联网行业,利用自身积累的技术优势、行业经验、深度合作伙伴关系等,向广大中小型企业、政府机构等提供互联网行业的解决方案,青山湖网站推广取得了明显的社会效益与经济效益。目前,我们服务的客户以成都为中心已经辐射到青山湖省份的部分城市,未来相信会继续扩大服务区域并继续获得客户的支持与信任!

1. 拦截器获取参数,判断是否有Page类

1) 使用ThreadLocal 获取

//获取ThreadLocal
private static ThreadLocal pageLocal = new ThreadLocal();
private Page getPage() {
  return pageLocal.get();
}

2) 从boundsql里面获取

BoundSql boundSql = delegate.getBoundSql();
Object parameterObject = boundSql.getParameterObject();
Page page = this.getPage(parameterObject);
private Page getPage(Object parameterObject) {
    Page page = null;
    if (parameterObject instanceof Page) {
      page = (Page) parameterObject;
    } else if (parameterObject instanceof Map) {
      for (Object val : ((Map) parameterObject).values()) {
        if (val instanceof Page) {
          page = (Page) val;
        }
      }
    }
    return page;
  }

2. 重载plugin方法

@Override
public Object plugin(Object target) {
  if (target instanceof StatementHandler) {
    return Plugin.wrap(target, this);
  } else {
    return target;
  }
}

关于使用Mybatis进行分页时需要注意哪些事项问题的解答就分享到这里了,希望以上内容可以对大家有一定的帮助,如果你还有很多疑惑没有解开,可以关注创新互联行业资讯频道了解更多相关知识。


分享标题:使用Mybatis进行分页时需要注意哪些事项-创新互联
文章起源:http://ybzwz.com/article/dcegoj.html