最新下载
热门教程
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
Mybatis实现分页的注意点
时间:2022-06-29 01:26:12 编辑:袖梨 来源:一聚教程网
前面的话:使用拦截器给Mybatis进行分页的教程在网上有很多,这里记录的主要是我在使用的时候中间走的弯路,记录下来,也好给后面想要学习Mybatis分页拦截的小伙伴们提供点帮助。
1. 拦截器获取参数,判断是否有Page类
1) 使用ThreadLocal 获取
代码如下 | 复制代码 |
//获取ThreadLocal privatestaticThreadLocal privatePage getPage() { returnpageLocal.get(); } |
2) 从boundsql里面获取
代码如下 | 复制代码 |
BoundSql boundSql = delegate.getBoundSql(); Object parameterObject = boundSql.getParameterObject(); Page page =this.getPage(parameterObject); privatePage getPage(Object parameterObject) { Page page =null; if(parameterObjectinstanceofPage) { page = (Page) parameterObject; }elseif(parameterObjectinstanceofMap) { for(Object val : ((Map) parameterObject).values()) { if(valinstanceofPage) { page = (Page) val; } } } returnpage; } |
2. 重载plugin方法
代码如下 | 复制代码 |
@Override publicObject plugin(Object target) { if(targetinstanceofStatementHandler) { returnPlugin.wrap(target,this); }else{ returntarget; } } |
原文链接:http://blog.csdn.net/cubic__/article/details/75353932
相关文章
- 碧蓝航线欧根亲王μ兵装怎么获得 04-20
- 《明日方舟》钢铁萝卜矿场第八关攻略 04-20
- 物华弥新每月免费抽卡次数有多少 04-20
- im钱包安卓版官方版 04-20
- 中币网app2024 04-20
- im钱包app官网版 04-20