zoukankan      html  css  js  c++  java
  • PageHelper 分页和排序之间的关系

    (1)PageHelper是根据pageSize或者orderByOnly来判断是否要分页的,pageSize大于0 或者orderByOnly 为true才进行分页操作

        @Override
        public boolean beforePage(MappedStatement ms, Object parameterObject, RowBounds rowBounds) {
            Page page = getLocalPage();
            if (page.isOrderByOnly() || page.getPageSize() > 0) {
                return true;
            }
            return false;
        }

    (2)如果不进行分页则PageHelper的order by操作也是不进行的;如下是PageInterceptor类的部分代码:

                    if (dialect.beforePage(ms, parameter, rowBounds)) {
                        //生成分页的缓存 key
                        CacheKey pageKey = cacheKey;
                        //处理参数对象
                        parameter = dialect.processParameterObject(ms, parameter, boundSql, pageKey);
                        //调用方言获取分页 sql
                        String pageSql = dialect.getPageSql(ms, boundSql, parameter, rowBounds, pageKey);
                        BoundSql pageBoundSql = new BoundSql(configuration, pageSql, boundSql.getParameterMappings(), parameter);
                        //设置动态参数
                        for (String key : additionalParameters.keySet()) {
                            pageBoundSql.setAdditionalParameter(key, additionalParameters.get(key));
                        }
                        //执行分页查询
                        resultList = executor.query(ms, parameter, RowBounds.DEFAULT, resultHandler, pageKey, pageBoundSql);
                    } else {
                        //不执行分页的情况下,也不执行内存分页
                        resultList = executor.query(ms, parameter, RowBounds.DEFAULT, resultHandler, cacheKey, boundSql);
                    }

    当不分页时,是直接拿拦截获得的SQL进行查询的,所以没有组装 order by 语句

  • 相关阅读:
    C++逐行读取文本文件的正确做法
    <Android Framework 之路>Android5.1 Camera Framework(一)
    zeromq-4.1.2在windows下的编译
    Duilib应用修改程序图标方法
    gdal集成kml库的做法
    使用DWR实现JS调用服务端Java代码
    DirectUI界面编程(六)实现右键弹出菜单
    如何设计系统的错误码及错误信息
    TCP协议格式
    UDP协议
  • 原文地址:https://www.cnblogs.com/lzj123/p/11239666.html
Copyright © 2011-2022 走看看