医保上传统计

增加原始单据表索引
dev_fifo_z
qiuyt 6 months ago
parent 03fc415c3f
commit e4db91cb52

@ -172,6 +172,9 @@ public class IoCollectCodeBackup implements Serializable {
@ApiModelProperty(value = "是否拆零码")
private Boolean isSplitCode;
@TableField(value = "relCodeCount")
@ApiModelProperty(value = "关联关系数量")
private Integer relCodeCount;
private static final long serialVersionUID = 1L;
}

@ -186,6 +186,10 @@ public class CollectOrderBizResponse {
private String queueCode;
private Integer ledNum;
/**
*
*/
private Integer relCodeCount;

@ -13,6 +13,7 @@ import com.glxp.api.req.collect.CollectOrderBizRequest;
import com.glxp.api.req.collect.CollectOrderUploadCountRequest;
import com.glxp.api.res.collect.CollectOrderBizResponse;
import com.glxp.api.res.collect.CollectOrderUploadCountResponse;
import org.apache.commons.lang3.StringUtils;
import org.springframework.stereotype.Service;
import javax.annotation.Resource;
@ -85,14 +86,24 @@ public class IoCollectOrderBizBackupService extends ServiceImpl<IoCollectOrderBi
for (String buyType : buyTypeSales) {
if (buyType.equals(collectOrderBizResponse.getBusType())) {
// salesCount += collectOrderBizResponse.getCount();
salesScanCount ++;
if(collectOrderBizResponse.getRelCodeCount() != null && collectOrderBizResponse.getRelCodeCount() >0){
buyerScanCount += collectOrderBizResponse.getRelCodeCount();
}else {
buyerScanCount ++;
}
}
}
for (String buyType : buyTypeBuyer) {
if (buyType.equals(collectOrderBizResponse.getBusType())) {
// buyerCount += collectOrderBizResponse.getCount();
// 只有已上传的码才是正确的码
buyerScanCount ++;
if(collectOrderBizResponse.getRelCodeCount() != null && collectOrderBizResponse.getRelCodeCount() >0){
salesScanCount += collectOrderBizResponse.getRelCodeCount();
}else {
salesScanCount ++;
}
}
}
if(collectOrderBizResponse.getFifoSplit() == 1
@ -108,10 +119,15 @@ public class IoCollectOrderBizBackupService extends ServiceImpl<IoCollectOrderBi
}
}
if(collectOrderBizResponse.getRelCodeCount() != null && collectOrderBizResponse.getRelCodeCount() >0){
codeCount += collectOrderBizResponse.getRelCodeCount();
}else {
codeCount ++;
}
}
// 计算采购率和销售率
// BigDecimal buyerCountBigDecimal = BigDecimal.valueOf(buyerCount);

@ -0,0 +1,93 @@
package com.glxp.api.task;
import cn.hutool.core.collection.CollUtil;
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.glxp.api.common.res.BaseResponse;
import com.glxp.api.dao.collect.RelCodeDetailMapper;
import com.glxp.api.dao.schedule.ScheduledDao;
import com.glxp.api.entity.collect.IoCollectCode;
import com.glxp.api.entity.collect.IoCollectCodeBackup;
import com.glxp.api.entity.collect.RelCodeBatch;
import com.glxp.api.entity.collect.RelCodeDetail;
import com.glxp.api.entity.system.ScheduledEntity;
import com.glxp.api.req.system.ScheduledRequest;
import com.glxp.api.service.collect.IoCollectCodeBackService;
import com.glxp.api.service.collect.RelCodeBatchService;
import com.glxp.api.service.collect.RelCodeDetailService;
import com.glxp.api.util.CacheUtils;
import com.glxp.api.util.RedisUtil;
import com.glxp.api.util.redis.RedisDelayedQueue;
import lombok.extern.slf4j.Slf4j;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.scheduling.annotation.EnableScheduling;
import org.springframework.scheduling.annotation.SchedulingConfigurer;
import org.springframework.scheduling.config.ScheduledTaskRegistrar;
import org.springframework.scheduling.support.CronTrigger;
import org.springframework.stereotype.Component;
import redis.clients.jedis.resps.Tuple;
import javax.annotation.Resource;
import java.util.*;
@Component
@EnableScheduling
@Slf4j
public class CollectOrderEelCodeCountTask implements SchedulingConfigurer {
@Resource
private ScheduledDao scheduledDao;
@Resource
private IoCollectCodeBackService ioCollectCodeBackService;
@Resource
private RelCodeDetailMapper relCodeDetailMapper;
@Override
public void configureTasks(ScheduledTaskRegistrar scheduledTaskRegistrar) {
scheduledTaskRegistrar.addTriggerTask(() -> process(),
triggerContext -> {
ScheduledRequest scheduledRequest = new ScheduledRequest();
scheduledRequest.setCronName("collectOrderEelCodeCountTask");
ScheduledEntity scheduledEntity = scheduledDao.findScheduled(scheduledRequest);
if (scheduledEntity == null) {
return null;
}
String cron = scheduledEntity.getCron();
if (cron.isEmpty()) {
log.error("cron is null");
}
return new CronTrigger(cron).nextExecutionTime(triggerContext);
});
}
private void process() {
LambdaQueryWrapper<IoCollectCodeBackup> lambdaQueryWrapper =new LambdaQueryWrapper();
lambdaQueryWrapper.gt(IoCollectCodeBackup::getRelCodeCount,-2);
List<IoCollectCodeBackup> list = ioCollectCodeBackService.list(
lambdaQueryWrapper
);
if(list!=null ){
for (IoCollectCodeBackup ioCollectCodeBackup : list) {
int count = relCodeDetailMapper.selectCount(
new LambdaQueryWrapper<RelCodeDetail>()
.eq(RelCodeDetail::getParentCode,ioCollectCodeBackup.getCode())
).intValue();
IoCollectCodeBackup ioCollectCodeBackupNew = new IoCollectCodeBackup();
if(count > 0){
ioCollectCodeBackupNew.setRelCodeCount(count);
}else {
ioCollectCodeBackupNew.setRelCodeCount(ioCollectCodeBackup.getRelCodeCount()-1);
}
ioCollectCodeBackService.update(
ioCollectCodeBackupNew,new LambdaQueryWrapper<IoCollectCodeBackup>()
.eq(IoCollectCodeBackup::getId,ioCollectCodeBackup.getId())
);
}
}
}
}

@ -39,7 +39,7 @@
</select>
<select id="getList" resultType="com.glxp.api.res.collect.CollectOrderBizResponse">
SELECT
biz_bac.* ,bac.busType,bac.uploadStatus,code_ba.fifoSplit
biz_bac.* ,bac.busType,bac.uploadStatus,code_ba.fifoSplit,code_ba.relCodeCount
FROM
io_collect_code_backup code_ba LEFT JOIN io_collect_order_backup bac ON code_ba.billNo = bac.billNo
LEFT JOIN io_collect_order_biz_backup biz_bac ON biz_bac.orderIdFk = bac.billNo

@ -5209,3 +5209,12 @@ CREATE TABLE IF NOT EXISTS `sys_order_led`
INSERT IGNORE INTO `sys_scheduled` (`id`, `cronName`, `cron`, `customerId`, `remark`)
VALUES (165, 'LedClearTask', '0 */1 * * * ?', NULL, '自动查询未关闭灯组');
CALL Pro_Temp_ColumnWork('io_collect_code_backup', 'relCodeCount',
' int DEFAULT ''0'' COMMENT ''关联关系数量''',
1);
INSERT IGNORE INTO sys_scheduled( `cronName`, `cron`, `customerId`, `remark`)
VALUES ('collectOrderEelCodeCountTask', '0 0 */8 * * *', NULL, '定时拉取关联关系数量到上传医保码表');
call Modify_UNIQUE_index('io_collect_order_origin', 'billNo`, `orderTime`, `createTime`, `tagStatus', 'idx_io_collect_order_all', 'INDEX');

Loading…
Cancel
Save