screen-common/src/main/java/com/moral/util/DateUtils.java
@@ -80,6 +80,10 @@ * 日期格式(yyyy-MM-dd HH) * */ public static final String yyyy_MM_dd_HH_EN = "yyyy-MM-dd HH"; /* * 日期格式(MM-dd) * */ public static final String MM_dd_EN = "MM-dd"; /* * Date类toString格式 screen-job/src/main/java/com/moral/api/service/impl/CityAqiMonthlyServiceImpl.java
@@ -2,6 +2,7 @@ import com.alibaba.fastjson.JSONObject; import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; import com.baomidou.mybatisplus.core.conditions.update.UpdateWrapper; import com.moral.api.entity.CityAqiDaily; import com.moral.api.entity.CityAqiMonthly; import com.moral.api.mapper.CityAqiMonthlyMapper; @@ -57,6 +58,20 @@ //结束时间,本月1号 Date end = DateUtils.addMonths(start, 1); //如果是1号,先删除上月数据再统计 //不是1号,统计的是本月累计值,先删除本月数据 int day = DateUtils.getDay(new Date()); UpdateWrapper<CityAqiMonthly> cityAqiMonthlyUpdateWrapper = new UpdateWrapper<>(); if (day == 1) { cityAqiMonthlyUpdateWrapper.eq("time", start); } else { start = end; end = DateUtils.addMonths(start, 1); lastLastMonth = DateUtils.addMonths(start, -1); cityAqiMonthlyUpdateWrapper.eq("time", start); } cityAqiMonthlyMapper.delete(cityAqiMonthlyUpdateWrapper); //获取所有城市aqi小时数据 QueryWrapper<CityAqiDaily> wrapper = new QueryWrapper<>(); @@ -83,11 +98,12 @@ List<CityAqiMonthly> cityAqiMonthlyList = new ArrayList<>(); Date finalStart = start; data.forEach((cityCode, value) -> { CityAqiMonthly cityAqiMonthly = new CityAqiMonthly(); Map<String, Object> jsonMap = new HashMap<>(); cityAqiMonthly.setCityCode(Integer.parseInt(cityCode)); cityAqiMonthly.setTime(start); cityAqiMonthly.setTime(finalStart); Map<String, Object> params = new HashMap<>(); List<Map<String, Object>> temp = new ArrayList<>(); screen-job/src/main/java/com/moral/api/service/impl/CityAqiYearlyServiceImpl.java
@@ -2,6 +2,7 @@ import com.alibaba.fastjson.JSONObject; import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; import com.baomidou.mybatisplus.core.conditions.update.UpdateWrapper; import com.moral.api.entity.CityAqiDaily; import com.moral.api.entity.CityAqiYearly; import com.moral.api.mapper.CityAqiYearlyMapper; @@ -18,7 +19,6 @@ import java.text.DecimalFormat; import java.util.ArrayList; import java.util.Arrays; import java.util.Date; import java.util.HashMap; import java.util.List; @@ -59,6 +59,20 @@ //结束时间,本年1号 Date end = DateUtils.getDate(DateUtils.getDateAddYear(DateUtils.dateToDateString(start, DateUtils.yyyy), 1), DateUtils.yyyy); //如果是1月1号,先删除去年数据 //不是1月1号,统计的是本年累计值,先删除本年数据 String monthAndDay = DateUtils.dateToDateString(new Date(), DateUtils.MM_dd_EN); UpdateWrapper<CityAqiYearly> cityAqiYearlyUpdateWrapper = new UpdateWrapper<>(); if ("01-01".equals(monthAndDay)) { cityAqiYearlyUpdateWrapper.eq("time", start); } else { start = end; end = DateUtils.getDate(DateUtils.getDateAddYear(DateUtils.dateToDateString(start, DateUtils.yyyy), 1), DateUtils.yyyy); lastLastYear = DateUtils.getDate(DateUtils.getDateAddYear(DateUtils.dateToDateString(start, DateUtils.yyyy), -1), DateUtils.yyyy); cityAqiYearlyUpdateWrapper.eq("time", start); } cityAqiYearlyMapper.delete(cityAqiYearlyUpdateWrapper); //获取所有城市aqi日数据 QueryWrapper<CityAqiDaily> wrapper = new QueryWrapper<>(); @@ -85,11 +99,12 @@ List<CityAqiYearly> cityAqiYearlyList = new ArrayList<>(); Date finalStart = start; data.forEach((cityCode, value) -> { CityAqiYearly cityAqiYearly = new CityAqiYearly(); Map<String, Object> jsonMap = new HashMap<>(); cityAqiYearly.setCityCode(Integer.parseInt(cityCode)); cityAqiYearly.setTime(start); cityAqiYearly.setTime(finalStart); //PM2.5 Double pm25Avg = AmendUtils.getAvgOfYear(value, "PM2_5");