源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

Mybatis实现分页的注意点

  • 时间:2022-09-26 10:44 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:Mybatis实现分页的注意点
[b]前面的话:[/b]使用拦截器给Mybatis进行分页的教程在网上有很多,这里记录的主要是我在使用的时候中间走的弯路,记录下来,也好给后面想要学习Mybatis分页拦截的小伙伴们提供点帮助。 [b]1. 拦截器获取参数,判断是否有Page类[/b] 1) 使用ThreadLocal 获取
//获取ThreadLocal
private static ThreadLocal<Page> pageLocal = new ThreadLocal<Page>();
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;
  }
}
[b]总结[/b] 以上所述是小编给大家介绍的Mybatis实现分页的注意点,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对编程素材网网站的支持!
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部