PageHelper 可以在分页的同时获取条件对应的 sum 吗?比如总金额。

 复制源码到自己的项目

Dialect 增加方法 
AbstractHelperDialect 实现方法
@Override
    public boolean afterCount(Object obj, Object parameterObject, RowBounds rowBounds) {
        //某些数据(如 TDEngine)查询 count 无结果时返回 null
        Page page = getLocalPage();
        Long count = 0L;
        if (Objects.nonNull(obj)) {
            Object data = ((List) obj).get(0);
            if ("java.lang.Number".equals(data.getClass().getSuperclass().getName())) {
                count = ((Number) data).longValue();
            } else {
                JSONObject jsonObject = ((JSONObject) data);
                count = jsonObject.getLong("count");
                Map<String, Object> sumList = page.getSumList();
                if (CollectionUtil.isNotEmpty(sumList)) {
                    String[] keys = sumList.keySet().toArray(new String[]{});
                    page.getSumList().clear();
                    for (String key : keys) {
                        String[] ass = key.split("\\.");
                        String as = key;
                        if (ass.length > 1) {
                            as = ass[1];
                        }
                        page.getSumList().put(as, jsonObject.get(as));
                    }
                }
            }
        }
        page.setTotal(count);
        if (rowBounds instanceof PageRowBounds) {
            ((PageRowBounds) rowBounds).setTotal(count);
        }
        //pageSize < 0 的时候,不执行分页查询
        //pageSize = 0 的时候,还需要执行后续查询,但是不会分页
        if (page.getPageSizeZero() != null) {
            //PageSizeZero=false&&pageSize<=0
            if (!page.getPageSizeZero() && page.getPageSize() <= 0) {
                return false;
            }
            //PageSizeZero=true&&pageSize<0 返回 false,只有>=0才需要执行后续的
            else if (page.getPageSizeZero() && page.getPageSize() < 0) {
                return false;
            }
        }
        //页码>0 && 开始行数<总行数即可,不需要考虑 pageSize(上面的 if 已经处理不符合要求的值了)
        return page.getPageNum() > 0 && count > page.getStartRow();
    }

修改方法

 修改方法

 添加属性

 修改方法

 使用

思路:

找到执行汇总前,把你要汇总的字段添加到sql字符串中,再想办法返回对应的对象,注意要兼容不要影响不需要汇总的conut就可以了 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
您好!要使用PageHelper进行条件查询分页,您需要遵循以下步骤: 1. 首先,请确保您已经将PageHelper库添加到您的项目中。可以通过在Maven或Gradle配置文件中添加依赖项来实现。 2. 在您的查询方法中,传入PageHelper.startPage(pageNum, pageSize)来指定页码和每页显示的数据量。这将在查询之前启动分页功能。 3. 定义您的查询条件。可以使用MyBatis或其他ORM框架提供的方式来构建查询条件,例如使用注解或XML配置。 4. 执行查询操作,并将查询结果封装到一个List或其他集合类型中。 5. 最后,可以通过PageInfo类获取分页的相关信息,例如当前页码、总页数、总记录数等。 以下是一个示例代码片段,展示了如何使用PageHelper进行条件查询分页: ```java import com.github.pagehelper.PageHelper; import com.github.pagehelper.PageInfo; public List<User> searchUserByCondition(String name, int pageNum, int pageSize) { // 开启分页 PageHelper.startPage(pageNum, pageSize); // 构建查询条件 Example example = new Example(User.class); Example.Criteria criteria = example.createCriteria(); criteria.andLike("name", "%" + name + "%"); // 执行查询 List<User> userList = userDao.selectByExample(example); // 获取分页信息 PageInfo<User> pageInfo = new PageInfo<>(userList); return pageInfo.getList(); } ``` 在上述示例中,我们通过调用`PageHelper.startPage(pageNum, pageSize)`来启动分页功能,然后构建查询条件,并执行查询操作。最后,使用PageInfo类获取分页信息并返回查询结果。 希望以上信息能够帮助到您!如果还有其他问题,请随时提问。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值