mybatis 实现分页 Mybatis实现分页的注意点
Spade-A 人气:2想了解Mybatis实现分页的注意点的相关内容吗,Spade-A在本文为您仔细讲解mybatis 实现分页的相关知识和一些Code实例,欢迎阅读和指正,我们先划重点:mybatis,实现分页,下面大家一起来学习吧。
前面的话:使用拦截器给Mybatis进行分页的教程在网上有很多,这里记录的主要是我在使用的时候中间走的弯路,记录下来,也好给后面想要学习Mybatis分页拦截的小伙伴们提供点帮助。
1. 拦截器获取参数,判断是否有Page类
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; } }
总结
以上所述是小编给大家介绍的Mybatis实现分页的注意点,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
加载全部内容