最新下载
热门教程
- 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
相关文章
- 胜利女神新的希望A2怎么玩 A2技能机制详细解析 07-10
- 《QQ》群主转让给管理员方法 07-10
- swap的价格和价值 07-10
- 为什么有些微信公众号能拿下数千万的风投你却不行? 07-10
- 剑星蝴蝶拍照位置在哪-剑星蝴蝶拍照地点 07-10
- Win11家庭版如何转换到专业版 Win11家庭版升级专业版的方法 07-10