芋道-分组统计分页

需求:按每天统计数据

EarningSettleCompanyRespVO文件

package cn.iocoder.yudao.module.nlm.controller.admin.earningsettle.vo;

import io.swagger.v3.oas.annotations.media.Schema;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;

import java.math.BigDecimal;
import java.time.LocalDate;

@Schema(description = "管理后台 - 企业结算统计 Response VO")
@Data
@NoArgsConstructor
@AllArgsConstructor
public class EarningSettleCompanyRespVO {

    @Schema(description = "当日收入", example = "100.20")
    private BigDecimal dailyIncome;

    @Schema(description = "日95总宽带", example = "100.20")
    private BigDecimal nineFive;

    @Schema(description = "移动设备宽带", example = "100.20")
    private BigDecimal mobileBroadband;

    @Schema(description = "移动设备奖励", example = "100.20")
    private BigDecimal mobileIncome;

    @Schema(description = "电信设备宽带", example = "100.20")
    private BigDecimal telecomBroadband;

    @Schema(description = "电信设备奖励", example = "100.20")
    private BigDecimal telecomIncome;

    @Schema(description = "联通设备宽带", example = "100.20")
    private BigDecimal unicomBroadband;

    @Schema(description = "联通设备奖励", example = "100.20")
    private BigDecimal unicomIncome;

    @Schema(description = "结算日期")
    private LocalDate settleDate;

    private Long userId;
}

Controller文件

	@GetMapping("/company")
    @Operation(summary = "获得收益结算明细分页")
    @PreAuthorize("@ss.hasPermission('nlm:earning-settle:company')")
    public CommonResult<PageResult<EarningSettleCompanyRespVO>> getCompanyEarningSettlePage(EarningSettleCompanyPageReqVO pageVO) {

        PageResult<EarningSettleCompanyRespVO> pageResult = earningSettleService.getCompanyEarningSettlePage(pageVO);

        return success(pageResult);
    }

Service文件

    /**
     * 统计每一天的企业结算数据
     * @return PageResult
     */
    PageResult<EarningSettleCompanyRespVO> getCompanyEarningSettlePage(EarningSettleCompanyPageReqVO pageVO);

ServiceImpl文件

    @Override
    public PageResult<EarningSettleCompanyRespVO> getCompanyEarningSettlePage(EarningSettleCompanyPageReqVO pageVO) {
        // 验证角色,管理员查看全部,非管理员只查看自己的
        AdminUserDO adminUserDO = adminUserMapper.selectById(getLoginUserId());
        if(adminUserDO == null || !(adminUserDO.getType().equals(TypeEnum.ADMIN.getType()) || adminUserDO.getType().equals(TypeEnum.SUPER_ADMIN.getType()))){
            pageVO.setUserId(getLoginUserId());
        }else{
            pageVO.setUserId(null);
        }
        return earningSettleMapper.getCompanyEarningSettlePage(pageVO);
    }

mapper文件

default PageResult<EarningSettleCompanyRespVO> getCompanyEarningSettlePage(EarningSettleCompanyPageReqVO pageVO){
        IPage<EarningSettleCompanyRespVO> iPage = MyBatisUtils.buildPage(pageVO);

        QueryWrapperX<EarningSettleCompanyRespVO> queryWrapperX = new QueryWrapperX<>();
        queryWrapperX.eqIfPresent("settle_date", pageVO.getSettleDate());
        queryWrapperX.eqIfPresent("user_id", pageVO.getUserId());
        queryWrapperX.groupBy("settle_date");

        List<EarningSettleCompanyRespVO> list = getCompanyEarningSettleList(iPage, queryWrapperX);

        return new PageResult<>(list, iPage.getTotal());
    }

    List<EarningSettleCompanyRespVO> getCompanyEarningSettleList(IPage<EarningSettleCompanyRespVO> iPage, @Param("ew") QueryWrapperX<EarningSettleCompanyRespVO> ew);

xml文件

    <select id="getCompanyEarningSettleList"
            resultType="cn.iocoder.yudao.module.nlm.controller.admin.earningsettle.vo.EarningSettleCompanyRespVO">
        select
            sum(money) as dailyIncome,
            sum(if(equipment_type = 0, nine_five, 0)) as mobileBroadband,
            sum(if(equipment_type = 0, money, 0)) as mobileIncome,
            sum(if(equipment_type = 1, nine_five, 0)) as unicomBroadband,
            sum(if(equipment_type = 1, money, 0)) as unicomIncome,
            sum(if(equipment_type = 2, nine_five, 0)) as telecomBroadband,
            sum(if(equipment_type = 2, money, 0)) as telecomIncome,
            settle_date
        from nlm_earning_settle
        ${ew.customSqlSegment}

    </select>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值