private static  final Integer pageSize=100000;
/**
     * zcc
     * @param fixmedinsCode
     * @param title
     * @param sheetName
     */
    public void exportAudtMorethanVo(String fixmedinsCode,String title, String sheetName) {
        String filePath = excelPath + fixmedinsCode;
        FileUtils.createFile(filePath);
        // 指定导出的文件路径
        FileOutputStream fos = null;
        Workbook workbook = null;
        try {

            LoginUser sysUser = (LoginUser) SecurityUtils.getSubject().getPrincipal();
            ExportParams exportParams = new ExportParams(title + "报表", "导出人:" + sysUser.getRealname(), sheetName);
            exportParams.setMaxNum(1048576);
            exportParams.setType(ExcelType.XSSF);
            workbook = ExcelExportUtil.exportBigExcel(exportParams, AudtMorethanVo.class, new IExcelExportServer() {
                /**
                 * obj 限制条件
                 * page 是页数,他是在分页进行文件转换,page每次+1
                 */
                @Override
                public List<Object> selectListForExcelExport(Object obj, int page) {
                    //page每次加一,当等于obj的值时返回空,代码结束;
                    if (((int) obj) == page) {
                        return null;
                    }
                    List<AudtMorethanVo> audtMorethanVos = null;
                    try {
                        audtMorethanVos = audtFixmedinsService.selectAudtMorethanVoByfixmedinsCodeByPage(fixmedinsCode,null, page, pageSize);
                    } catch (Exception e) {
                        e.printStackTrace();
                    }
                    return CollectionUtil.isNotEmpty(audtMorethanVos)?Arrays.asList(audtMorethanVos.toArray()):null;
                }
            }, pageSize);
            String fileName = workbook.getSheetAt(0).getSheetName();//sheet名字当文件名称
            fos = new FileOutputStream(filePath + "/" + fileName + ".xlsx");
            workbook.write(fos);
        } catch (Exception e) {
            e.printStackTrace();
        } finally {
            if (fos != null) {
                try {
                    fos.close();
                    workbook.close();
                } catch (Exception e) {
                    e.printStackTrace();
                }
            }
        }


    }

  

/**
     * zcc
     * 创建文件夹;
     * @param path 路径
     */
    public static void createFile(String path) {
        File file = new File(path);
        //判断文件是否存在;
        if (!file.exists()) {
            //创建文件;
            file.mkdirs();
        }
    }

  

@Data
@ApiModel(value="AudtMorethanVo对象")
public class AudtMorethanVo implements Serializable {

    private static final long serialVersionUID = 1L;
    /**问题分类ID*/
//    @Excel(name = "问题分类ID", width = 15)
    @ApiModelProperty(value = "问题分类ID")
    private String proclationid;

    /**项目*/
    @Excel(name = "项目", width = 15)
    @ApiModelProperty(value = "项目")
    private String protName;

    /**问题描述*/
    @Excel(name = "问题描述", width = 60)
    @ApiModelProperty(value = "问题描述")
    private String probDestion;

    /**定点医药机构编号*/
    @Excel(name = "定点医药机构编号", width = 15)
    @ApiModelProperty(value = "定点医药机构编号")
    private String fixmedinsCode;
    /**定点医药机构名称*/
    @Excel(name = "定点医药机构名称", width = 15)
    @ApiModelProperty(value = "定点医药机构名称")
    private String fixmedinsName;
    /**结算ID*/
    @Excel(name = "结算ID", width = 15)
    @ApiModelProperty(value = "结算ID")
    private String setlId;
    /**证件号码*/
    @Excel(name = "证件号码", width = 15)
    @ApiModelProperty(value = "证件号码")
    private String certno;
    /**人员姓名*/
    @Excel(name = "人员姓名", width = 15)
    @ApiModelProperty(value = "人员姓名")
    private String psnName;
    /**性别*/
    @Excel(name = "性别", width = 15)
    @ApiModelProperty(value = "性别")
    private String gend;
    /**年龄*/
    @Excel(name = "年龄", width = 15)
    @ApiModelProperty(value = "年龄")
    private String age;
    /**住院号*/
    @Excel(name = "住院号", width = 15)
    @ApiModelProperty(value = "住院号")
    private String iptOtpNo;
    /**出院科室*/
    @Excel(name = "出院科室", width = 15)
    @ApiModelProperty(value = "出院科室")
    private String dscgDeptName;
    /**住院天数*/
    @Excel(name = "住院天数", width = 15)
    @ApiModelProperty(value = "住院天数")
    private String iptDays;
    /**入院日期*/
    @Excel(name = "入院日期", width = 15, format = "yyyy-MM-dd")
    @JsonFormat(timezone = "GMT+8",pattern = "yyyy-MM-dd")
    @DateTimeFormat(pattern="yyyy-MM-dd")
    @ApiModelProperty(value = "入院日期")
    private Date begndate;
    /**出院日期*/
    @Excel(name = "出院日期", width = 15, format = "yyyy-MM-dd")
    @JsonFormat(timezone = "GMT+8",pattern = "yyyy-MM-dd")
    @DateTimeFormat(pattern="yyyy-MM-dd")
    @ApiModelProperty(value = "出院日期")
    private Date enddate;
    /**医疗类别*/
    @Excel(name = "医疗类别", width = 15)
    @ApiModelProperty(value = "医疗类别")
    private String medType;
    /**医保目录名称*/
    @Excel(name = "医保目录名称", width = 35)
    @ApiModelProperty(value = "医保目录名称")
    private String mxHilistName;
    /**医保目录编码*/
    @Excel(name = "医保目录编码", width = 35)
    @ApiModelProperty(value = "医保目录编码")
    private String mxHilistCode;
    /**收费时间*/
    @Excel(name = "收费时间", width = 15, format = "yyyy-MM-dd")
    @JsonFormat(timezone = "GMT+8",pattern = "yyyy-MM-dd")
    @DateTimeFormat(pattern="yyyy-MM-dd")
    @ApiModelProperty(value = "收费时间")
    private Date mxFeeOcurTime;
    /**收取数量*/
    @Excel(name = "收取数量", width = 15,type = 4)
    @ApiModelProperty(value = "收取数量")
    private Integer mxCnt;
    /**金额*/
    @Excel(name = "金额", width = 15,type = 4)
    @ApiModelProperty(value = "金额")
    private BigDecimal mxFeeSumamt;
    /**单价*/
    @Excel(name = "单价", width = 15,type = 4)
    @ApiModelProperty(value = "单价")
    private Integer mxPric;
    /**超出数量*/
    @Excel(name = "超出数量", width = 15,type = 4)
    @ApiModelProperty(value = "超出数量")
    private Integer iptDaysExceed;
    /**超出金额*/
    @Excel(name = "超出金额", width = 15,type = 4)
    @ApiModelProperty(value = "超出金额")
    private BigDecimal feeSumamtExceed;
    /**违规数量*/
    @Excel(name = "违规数量", width = 15,type = 4)
    @ApiModelProperty(value = "违规数量")
    private Integer mxVitionNumber;
    /**违规金额*/
    @Excel(name = "违规金额", width = 15,type = 4)
    @ApiModelProperty(value = "违规金额")
    private BigDecimal mxVitionAmount;
}

  Mapper:

List<AudtMorethanVo> selectAudtMorethanVoByfixmedinsCodeByPage(@Param("fixmedinsCode") String fixmedinsCode, @Param("protName") String protName,@Param("pageNum") Integer pageNum,@Param("pageSize")Integer pageSize);

  XML:

<select id="selectAudtMorethanVoByfixmedinsCodeByPage"  resultType="com.frkj.modules.fund.common.vo.AudtMorethanVo">
        SELECT * FROM (

            SELECT e.*, ROWNUM rnum FROM (
                select
                b.proclation,
                b.prot_name ,
                b.prob_destion ,
                a.fixmedins_code,
                a.fixmedins_name,
                a.setl_id,
                a.certno,
                a.psn_name,
                a.gend,
                a.age,
                a.ipt_otp_no,
                a.dscg_dept_name,
                a.ipt_days,
                a.begndate,
                a.enddate,
                a.med_type,
                a.mx_hilist_name,
                a.mx_hilist_code,
                a.mx_fee_ocur_time,
                a.mx_cnt,
                a.mx_fee_sumamt,
                a.mx_pric,
                a.ipt_days_exceed,
                a.fee_sumamt_exceed,
                a.mx_vition_number,
                a.mx_vition_amount
                from AUDT_Morethan a,AUDT_RU b
                where a.vtionsueid=b.vtionsueid
                <if test="fixmedinsCode!=null and fixmedinsCode!=''">
                    and a.fixmedins_code=#{fixmedinsCode}
                </if>
                <if test="protName!=null and protName!=''">
                    and b.prot_name=#{protName}
                </if>
                order by a.vtionsueid,a.setl_id,a.mx_fee_ocur_time

            ) e WHERE ROWNUM <= #{pageNum} * #{pageSize}

        ) WHERE rnum > (#{pageNum} - 1) * #{pageSize}

    </select>

  个人电脑测试结果:

 

 

 

 

 

 

 

 

posted on 2024-06-14 11:10  西门夜说  阅读(60)  评论(0编辑  收藏  举报