gpt4 book ai didi

Mybatis实现分页的注意点

转载 作者:qq735679552 更新时间:2022-09-28 22:32:09 26 4
gpt4 key购买 nike

CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.

这篇CFSDN的博客文章Mybatis实现分页的注意点由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.

前面的话:使用拦截器给Mybatis进行分页的教程在网上有很多,这里记录的主要是我在使用的时候中间走的弯路,记录下来,也好给后面想要学习Mybatis分页拦截的小伙伴们提供点帮助.

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

1) 使用ThreadLocal 获取 。

?
1
2
3
4
5
//获取ThreadLocal
private static ThreadLocal<Page> pageLocal = new ThreadLocal<Page>();
private Page getPage() {
   return pageLocal.get();
}

2) 从boundsql里面获取 。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
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方法 。

?
1
2
3
4
5
6
7
8
@Override
public Object plugin(Object target) {
   if (target instanceof StatementHandler) {
     return Plugin.wrap(target, this );
   } else {
     return target;
   }
}

总结 。

以上所述是小编给大家介绍的Mybatis实现分页的注意点,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对我网站的支持! 。

原文链接:http://blog.csdn.net/cubic__/article/details/75353932 。

最后此篇关于Mybatis实现分页的注意点的文章就讲到这里了,如果你想了解更多关于Mybatis实现分页的注意点的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com