燕山石化溯源三维电子沙盘-【后端】-服务
13693261870
2023-06-06 b93e26dd7bcba7afdd6c554d22c644ae11281266
根据时间删除Voc数据
已添加1个文件
已修改4个文件
100 ■■■■■ 文件已修改
src/main/java/com/yssh/dao/VocValsMapper.java 8 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/main/java/com/yssh/scheduled/ReadCsvTask.java 6 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/main/java/com/yssh/service/VocValsService.java 5 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/main/java/com/yssh/utils/FileUtils.java 76 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/main/resources/mapping/VocValsMapper.xml 5 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/main/java/com/yssh/dao/VocValsMapper.java
@@ -52,4 +52,12 @@
     * @return å½±å“è¡Œæ•°
     */
    public int deleteLastYear();
    /**
     * æ ¹æ®æ—¶é—´åˆ é™¤æ•°æ®
     *
     * @param time æ—¶é—´ï¼ˆç¤ºä¾‹ï¼š2023060514)
     * @return å½±å“è¡Œæ•°
     */
    public int deleteByTime(@Param("time") String time);
}
src/main/java/com/yssh/scheduled/ReadCsvTask.java
@@ -2,8 +2,10 @@
import java.io.File;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.Calendar;
import java.util.Date;
import java.util.List;
import com.yssh.entity.VocVals;
import com.yssh.service.VocValsService;
@@ -47,7 +49,9 @@
    @Autowired
    private IWarningAnalyseService warningAnalyseService;
    private final SimpleDateFormat format = new SimpleDateFormat("yyyyMMddHH");
    private final static SimpleDateFormat format = new SimpleDateFormat("yyyyMMddHH");
    private final static List<String> md5List = new ArrayList<>();
    @Scheduled(cron = "${csv.cron}")
    public void corpReserveDataSync() {
src/main/java/com/yssh/service/VocValsService.java
@@ -44,6 +44,11 @@
        return vocValsMapper.deleteLastYear();
    }
    @Override
    public int deleteByTime(String time) {
        return vocValsMapper.deleteByTime(time);
    }
    @Async("threadPoolTaskExecutor")
    public int insertVocVals(List<VocVals> list) throws InterruptedException {
        List<List<VocVals>> lists = Lists.partition(list, IAsyncService.BATCH_INSERT_500);
src/main/java/com/yssh/utils/FileUtils.java
¶Ô±ÈÐÂÎļþ
@@ -0,0 +1,76 @@
package com.yssh.utils;
import java.io.File;
import java.io.FileInputStream;
import java.io.IOException;
import java.nio.ByteBuffer;
import java.nio.channels.FileChannel;
import java.security.MessageDigest;
/**
 * æ–‡ä»¶å·¥å…·ç±»
 * @author WWW
 * @date 2023-06-06
 */
public class FileUtils {
    public final static int SIXTEEN = 16;
    public static final char[] HEX_DIGITS = {'0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'a', 'b', 'c', 'd', 'e', 'f'};
    /**
     * 1.获取文件的MD5
     */
    @SuppressWarnings("unused")
    public static String getFileMd5(String filePath) {
        FileInputStream fis = null;
        try {
            MessageDigest md = MessageDigest.getInstance("MD5");
            fis = new FileInputStream(new File(filePath));
            FileChannel fChannel = fis.getChannel();
            ByteBuffer buffer = ByteBuffer.allocateDirect(1024 * 1024);
            while (fChannel.read(buffer) != -1) {
                buffer.flip();
                md.update(buffer);
                buffer.compact();
            }
            byte[] b = md.digest();
            return byteToHexString(b);
        } catch (Exception ex) {
            ex.printStackTrace();
            return null;
        } finally {
            try {
                if (null != fis) {
                    fis.close();
                }
            } catch (IOException ex) {
                ex.printStackTrace();
            }
        }
    }
    /**
     * å­—节码转16进制
     */
    public static String byteToHexString(byte[] tmp) {
        // æ¯ä¸ªå­—节用 16 è¿›åˆ¶è¡¨ç¤ºçš„话,使用两个字符,
        char[] str = new char[16 * 2];
        // æ‰€ä»¥è¡¨ç¤ºæˆ 16 è¿›åˆ¶éœ€è¦ 32 ä¸ªå­—符,表示转换结果中对应的字符位置
        int k = 0;
        // ä»Žç¬¬ä¸€ä¸ªå­—节开始,对 MD5 çš„æ¯ä¸€ä¸ªå­—节
        for (int i = 0; i < SIXTEEN; i++) {
            // è½¬æ¢æˆ 16 è¿›åˆ¶å­—符的转换
            byte byte0 = tmp[i];
            // å–字节中高 4 ä½çš„æ•°å­—转换
            str[k++] = HEX_DIGITS[byte0 >>> 4 & 0xf];
            // >>> ä¸ºé€»è¾‘右移,将符号位一起右移, å–字节中低 4 ä½çš„æ•°å­—转换
            str[k++] = HEX_DIGITS[byte0 & 0xf];
        }
        // æ¢åŽçš„结果转换为字符串
        return new String(str);
    }
}
src/main/resources/mapping/VocValsMapper.xml
@@ -42,4 +42,9 @@
        delete from voc_vals
        where create_time &lt; date_sub(now(), interval 1 year);
    </delete>
    <delete id="deleteByTime">
        delete from voc_vals
        where date_format(create_time, '%Y%m%d%H') = ${time};
    </delete>
</mapper>