From ad1cb1a11e642ce600d8480b8d3aa6a27f6732f9 Mon Sep 17 00:00:00 2001
From: jinpengyong <jpy123456>
Date: Wed, 14 Dec 2022 14:06:35 +0800
Subject: [PATCH] 国控站数据维护问题

---
 screen-job/src/main/java/com/moral/api/service/impl/ForecastServiceImpl.java |   15 ++++++++-------
 1 files changed, 8 insertions(+), 7 deletions(-)

diff --git a/screen-job/src/main/java/com/moral/api/service/impl/ForecastServiceImpl.java b/screen-job/src/main/java/com/moral/api/service/impl/ForecastServiceImpl.java
index 944dd08..1850370 100644
--- a/screen-job/src/main/java/com/moral/api/service/impl/ForecastServiceImpl.java
+++ b/screen-job/src/main/java/com/moral/api/service/impl/ForecastServiceImpl.java
@@ -57,9 +57,9 @@
     private CityAqiService cityAqiService;
 
     @Autowired
-    private ForecastService forecastService;
+    private ForecastMapper forecastMapper;
 
-    private static Map<String, Integer> weatherScore = new HashMap<>();
+    private static final Map<String, Integer> weatherScore = new HashMap<>();
 
     static {
         weatherScore.put("���", 100);
@@ -129,12 +129,11 @@
         //���������������������map
         Map<Date, List<Integer>> hours = DateUtils.getBeforeAndAfterHourDate(nextDay);
 
-        Forecast forecast = new Forecast();
+        List<Forecast> forecastList = new ArrayList<>();
+
         Map<String, Object> forecastMap = new HashMap<>();
         for (Object obj : cityCodes) {
             Integer cityCode = Integer.parseInt(obj.toString());
-
-            forecast.setCityCode(cityCode);
 
             //������
             List<CityWeatherForecast> cityWeatherForecasts = cityForecast.get(cityCode);
@@ -170,6 +169,8 @@
             }
 
             for (CityWeatherForecast cityWeatherForecast : cityWeatherForecasts) {
+                Forecast forecast = new Forecast();
+                forecast.setCityCode(cityCode);
                 Date time = cityWeatherForecast.getTime();
                 Map<String, Object> value = JSONObject.parseObject(cityWeatherForecast.getValue(), Map.class);
                 String weather = value.get("text").toString();
@@ -205,11 +206,11 @@
                 if (!Double.isNaN(o3Forecast)) {
                     forecastMap.put("O3", AmendUtils.sciCal(o3Forecast, 0));
                     forecast.setValue(JSONObject.toJSONString(forecastMap));
-                    forecastService.save(forecast);
+                    forecastList.add(forecast);
                 }
             }
-
         }
+        forecastMapper.insertForecast(forecastList);
     }
 
     private Double calculateAvg(List<Map<String, Object>> list, String param) {

--
Gitblit v1.8.0