使用Mybatis进行分页时需要注意哪些事项?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。
1. 拦截器获取参数,判断是否有Page类
1) 使用ThreadLocal 获取
//获取ThreadLocalprivate 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; }
重载plugin方法
@Overridepublic Object plugin(Object target) { if (target instanceof StatementHandler) { return Plugin.wrap(target, this); } else { return target; }}
关于使用Mybatis进行分页时需要注意哪些事项问题的解答就分享到这里了,希望以上内容可以对大家有一定的帮助,如果你还有很多疑惑没有解开,可以关注编程网行业资讯频道了解更多相关知识。