From 91c1c308abec43a67335cdebb574940ed41b09cf Mon Sep 17 00:00:00 2001
From: jinpengyong <jpy123456>
Date: Wed, 05 Aug 2020 16:56:16 +0800
Subject: [PATCH] 修改预测参数,提交到数据库
---
src/main/java/com/moral/mapper/ForecastWeatherMapper.java | 2
src/main/resources/mapper/DeviceMapper.xml | 5
src/main/resources/mapper/RealWeatherMapper.xml | 11 +
src/main/resources/mapper/HangzhouAqiMapper.xml | 4
src/main/java/com/moral/mapper/MonitorPointMapper.java | 1
src/main/java/com/moral/mapper/RealWeatherMapper.java | 2
src/main/resources/mapper/ForecastWeatherMapper.xml | 14 +
src/main/resources/mapper/MonitorPointMapper.xml | 292 +++++++++++++++-------------
src/main/java/com/moral/mapper/HistoryHourlyMapper.java | 4
src/main/java/com/moral/mapper/DeviceMapper.java | 2
src/main/java/com/moral/service/WeatherService.java | 2
src/main/resources/mapper/HistoryHourlyMapper.xml | 17 +
src/main/java/com/moral/controller/ScreenController.java | 7
src/main/java/com/moral/service/impl/WeatherServiceImpl.java | 214 +++++++++++++++++---
14 files changed, 393 insertions(+), 184 deletions(-)
diff --git a/src/main/java/com/moral/controller/ScreenController.java b/src/main/java/com/moral/controller/ScreenController.java
index a0149a3..ca6b595 100644
--- a/src/main/java/com/moral/controller/ScreenController.java
+++ b/src/main/java/com/moral/controller/ScreenController.java
@@ -1990,8 +1990,9 @@
return new ResultBean<List<Map<String, Object>>>(weatherList);
}
- @RequestMapping("updateForecastWeather")
- public void updateForecastWeather(@RequestBody List<Map<String,Object>> list) {
- weatherService.updateForecastWeather(list);
+ @PostMapping("updateForecastWeather")
+ public void updateForecastWeather(HttpServletRequest request){
+ Map<String, Object> parameters = getParametersStartingWith(request, null);
+ weatherService.updateForecastWeather(parameters);
}
}
diff --git a/src/main/java/com/moral/mapper/DeviceMapper.java b/src/main/java/com/moral/mapper/DeviceMapper.java
index ed36184..b2bd249 100644
--- a/src/main/java/com/moral/mapper/DeviceMapper.java
+++ b/src/main/java/com/moral/mapper/DeviceMapper.java
@@ -54,4 +54,6 @@
List<Integer> getHasWindDirAndWindSpeedDeviceVersion();
List<Device> selectDevicesAll(Map<String, Object> params);
+
+ List<Device> getDeviceListByMonitorPointIds(List<Integer> id);
}
\ No newline at end of file
diff --git a/src/main/java/com/moral/mapper/ForecastWeatherMapper.java b/src/main/java/com/moral/mapper/ForecastWeatherMapper.java
index fcbb705..24d8611 100644
--- a/src/main/java/com/moral/mapper/ForecastWeatherMapper.java
+++ b/src/main/java/com/moral/mapper/ForecastWeatherMapper.java
@@ -10,4 +10,6 @@
List<Map<String, Object>> getForecast(Map<String, Object> parameters);
void updateForecastWeather(Map<String, Object> parameters);
+
+ Map<String, Object> getPrecip6Hour(Map<String, Object> parameters);
}
diff --git a/src/main/java/com/moral/mapper/HistoryHourlyMapper.java b/src/main/java/com/moral/mapper/HistoryHourlyMapper.java
index 6c05d9a..e968bf7 100644
--- a/src/main/java/com/moral/mapper/HistoryHourlyMapper.java
+++ b/src/main/java/com/moral/mapper/HistoryHourlyMapper.java
@@ -2,6 +2,7 @@
import org.apache.ibatis.annotations.Param;
+import java.util.List;
import java.util.Map;
public interface HistoryHourlyMapper {
@@ -17,4 +18,7 @@
String getPressureByMac(@Param("mac") String mac,@Param("time") String time);
//������������
Map<String,Object> getDataByMac(@Param("mac") String mac,@Param("time") String time);
+
+ List<Map<String,Object>> getBeamByMacs(Map<String,Object> params);
+
}
diff --git a/src/main/java/com/moral/mapper/MonitorPointMapper.java b/src/main/java/com/moral/mapper/MonitorPointMapper.java
index 5023af1..7689907 100644
--- a/src/main/java/com/moral/mapper/MonitorPointMapper.java
+++ b/src/main/java/com/moral/mapper/MonitorPointMapper.java
@@ -31,4 +31,5 @@
MonitorPoint getFirstMonitorPointByProvinceCode(@Param("provinceCode") int provinceCode);
+ List<MonitorPoint> getMonitorList(Map<String, Object> params);
}
\ No newline at end of file
diff --git a/src/main/java/com/moral/mapper/RealWeatherMapper.java b/src/main/java/com/moral/mapper/RealWeatherMapper.java
index b8a4f87..2554ade 100644
--- a/src/main/java/com/moral/mapper/RealWeatherMapper.java
+++ b/src/main/java/com/moral/mapper/RealWeatherMapper.java
@@ -6,4 +6,6 @@
public interface RealWeatherMapper {
List<Map<String,Object>> getRealWeather(Map<String, Object> parameters);
+
+ Map<String, Object> getPrecip6Hour(Map<String, Object> parameters);
}
diff --git a/src/main/java/com/moral/service/WeatherService.java b/src/main/java/com/moral/service/WeatherService.java
index 08b6d6e..27c570f 100644
--- a/src/main/java/com/moral/service/WeatherService.java
+++ b/src/main/java/com/moral/service/WeatherService.java
@@ -14,5 +14,5 @@
List<Map<String, Object>> getWeatherData(Map<String, Object> parameters) throws ParseException;
- void updateForecastWeather(List<Map<String,Object>> list);
+ void updateForecastWeather(Map<String, Object> parameters);
}
diff --git a/src/main/java/com/moral/service/impl/WeatherServiceImpl.java b/src/main/java/com/moral/service/impl/WeatherServiceImpl.java
index 62d3544..1b326bd 100644
--- a/src/main/java/com/moral/service/impl/WeatherServiceImpl.java
+++ b/src/main/java/com/moral/service/impl/WeatherServiceImpl.java
@@ -24,13 +24,16 @@
import com.moral.entity.Area;
import com.moral.entity.AreaNames;
import com.moral.entity.City;
+import com.moral.entity.Device;
import com.moral.entity.MonitorPoint;
import com.moral.entity.Organization;
import com.moral.entity.Province;
import com.moral.mapper.AreaMapper;
import com.moral.mapper.CityMapper;
+import com.moral.mapper.DeviceMapper;
import com.moral.mapper.ForecastWeatherMapper;
import com.moral.mapper.HangzhouAqiMapper;
+import com.moral.mapper.HistoryHourlyMapper;
import com.moral.mapper.MonitorPointMapper;
import com.moral.mapper.ProvinceMapper;
import com.moral.mapper.RealWeatherMapper;
@@ -63,6 +66,12 @@
@Resource
private RealWeatherMapper realWeatherMapper;
+
+ @Resource
+ private DeviceMapper deviceMapper;
+
+ @Resource
+ private HistoryHourlyMapper historyHourlyMapper;
@Override
public Map<String, Object> getWeatherDataByRegion(Map<String, Object> parameters) {
@@ -179,7 +188,6 @@
parameters.put("start", sdf.parse(time));
parameters.put("end", sdf.parse(nextDay));
List<Map<String, Object>> forecastList = forecastWeatherMapper.getForecastHour(parameters);
-
MonitorPoint monitorPoint = monitorPointMapper.selectByPrimaryKey(Integer.valueOf(monitorPointId));
parameters.put("areaCode", monitorPoint.getAreaCode());
String sensors = "O3C";
@@ -192,7 +200,6 @@
parameters.put("areaCode", monitorPoint.getCityCode());
aqiList = hangzhouAqiMapper.getAqiDataByAreaCode(parameters);
}
-
for (Map<String, Object> map : aqiList) {
String O3 = map.get("O3").toString().replace("\"", "");
map.put("O3", O3);
@@ -225,7 +232,11 @@
hour = "24";
}
map.put("time", Integer.valueOf(hour));
- values.add(forecastMap.get("result").toString().replace("\"", ""));
+ if (forecastMap.get("result") != null) {
+ values.add(forecastMap.get("result").toString().replace("\"", ""));
+ } else {
+ values.add("");
+ }
values.add("");
map.put("values", values);
resultList.add(map);
@@ -239,7 +250,11 @@
hour = "24";
}
map.put("time", Integer.valueOf(hour));
- values.add(forecastMap.get("result").toString().replace("\"", ""));
+ if (forecastMap.get("result") != null) {
+ values.add(forecastMap.get("result").toString().replace("\"", ""));
+ } else {
+ values.add("");
+ }
for (Map<String, Object> aqiMap : aqiList) {
if (forecastMap.get("time").equals(aqiMap.get("time"))) {
values.add(aqiMap.get(sensor1).toString());
@@ -292,6 +307,14 @@
parameters.put("monitorPointId", monitorPoint.getId());
String time = parameters.get("time").toString();
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
+ SimpleDateFormat sdf1 = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
+ Date now = new Date();
+ Date selectTime = sdf1.parse(time + " 00:00:00");
+ Calendar c1 = Calendar.getInstance();
+ c1.setTime(selectTime);
+ c1.add(Calendar.DAY_OF_MONTH, -1);
+ Date beforeDay = c1.getTime();
+ String format = sdf.format(beforeDay);
Calendar c = Calendar.getInstance();
c.setTime(sdf.parse(time));
c.add(Calendar.HOUR_OF_DAY, 1);
@@ -301,17 +324,55 @@
parameters.put("start", start);
parameters.put("end", end);
List<Map<String, Object>> forecastList = forecastWeatherMapper.getForecast(parameters);
-
List<Map<String, Object>> foreList = new ArrayList<>();
-
for (Map<String, Object> map : forecastList) {
Map<String, Object> hashMap = new HashMap<>();
hashMap.put("time", map.get("time").toString());
hashMap.put("type", "������");
+ hashMap.put("TVOC", "");
+ hashMap.put("altitude", "");
+ hashMap.put("vegetation", "");
+ hashMap.put("AQI", "");
+ hashMap.put("SO2C", "");
+ hashMap.put("NO2C", "");
+ hashMap.put("COC", "");
+ hashMap.put("O3C", "");
+ hashMap.put("PM25C", "");
+ hashMap.put("PM10C", "");
hashMap.put("city", parameters.get("city").toString());
+
+ if (selectTime.getTime() <= now.getTime()) {
+ hashMap.put("fxTime", (format + " 15:00").substring(5, 16));
+ } else {
+ String s = sdf1.format(now).split(" ")[1].split(":")[0];
+ Integer hour = Integer.valueOf(s);
+ if (hour > 7) {
+ hashMap.put("fxTime", (format + " 07:00").substring(5, 16));
+ } else if (hour > 3 && hour < 7) {
+ hashMap.put("fxTime", (format + " 15:00").substring(5, 16));
+ }
+ }
Map<String, Object> jsonMap = (Map<String, Object>) JSONObject.parse(map.get("json").toString());
hashMap.putAll(jsonMap);
foreList.add(hashMap);
+ }
+
+ for (Map<String, Object> foreMap : foreList) {
+ String ftime = foreMap.get("time").toString();
+ Calendar calendar = Calendar.getInstance();
+ Date endTime = sdf1.parse(ftime);
+ calendar.setTime(endTime);
+ calendar.add(Calendar.HOUR, -6);
+ Date startTime = calendar.getTime();
+ Map<String, Object> hashMap = new HashMap<>();
+ hashMap.put("areaCode", Integer.valueOf(parameters.get("areaCode").toString()));
+ hashMap.put("start", startTime);
+ hashMap.put("end", endTime);
+ hashMap.put("monitorPointId", Integer.valueOf(parameters.get("monitorPointId").toString()));
+ Map<String, Object> precip6HourMap = forecastWeatherMapper.getPrecip6Hour(hashMap);
+ if (precip6HourMap != null) {
+ foreMap.put("precip6", precip6HourMap.get("precip6").toString());
+ }
}
List<Map<String, Object>> aqiList = hangzhouAqiMapper.getAqi(parameters);
@@ -330,8 +391,6 @@
realAqilist.add(hashMap);
}
- SimpleDateFormat sdf1 = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
-
for (Map<String, Object> map : realAqilist) {
Date endTime = sdf1.parse(map.get("time").toString());
c.setTime(endTime);
@@ -342,10 +401,40 @@
hashMap.put("start", startTime);
hashMap.put("end", endTime);
Map<String, Object> O3Map = hangzhouAqiMapper.getAvgO3EightHours(hashMap);
- map.put("O3������8������", O3Map.get("O3������8������").toString());
- if (O3Map.get("O3������8������") != null) {
- map.put("O3������8������", O3Map.get("O3������8������").toString());
+ map.put("O3_8H", O3Map.get("O3_8H").toString());
+ if (O3Map.get("O3C_8H") != null) {
+ map.put("O3C_8H", O3Map.get("O3C_8H").toString());
}
+ }
+
+ //������
+ String code = parameters.get("areaCode").toString();
+ Map<String, Object> params = new HashMap<>();
+ if (code.endsWith("00")) {
+ params.put("cityCode", Integer.valueOf(code));
+ } else {
+ params.put("areaCode", Integer.valueOf(code));
+ }
+
+ List<MonitorPoint> monitorList = monitorPointMapper.getMonitorList(params);
+
+ List<Integer> pointList = new ArrayList<>();
+ for (MonitorPoint point : monitorList) {
+ Integer pointId = point.getId();
+ pointList.add(pointId);
+ }
+
+ List<Device> deviceList = deviceMapper.getDeviceListByMonitorPointIds(pointList);
+ List<String> macList = new ArrayList<>();
+ List<Map<String, Object>> beamList = new ArrayList<>();
+ if (deviceList.size() != 0) {
+ for (Device device : deviceList) {
+ String mac = device.getMac();
+ macList.add(mac);
+ }
+
+ parameters.put("macs", macList);
+ beamList = historyHourlyMapper.getBeamByMacs(parameters);
}
List<Map<String, Object>> realList = realWeatherMapper.getRealWeather(parameters);
@@ -357,6 +446,28 @@
hashMap.putAll(jsonMap);
hashMap.put("city", parameters.get("city").toString());
realWeatherList.add(hashMap);
+ }
+
+ for (Map<String, Object> realMap : realWeatherList) {
+ String rtime = realMap.get("time").toString();
+ for (Map<String, Object> beamMap : beamList) {
+ String btime = realMap.get("time").toString();
+ if (btime.equals(rtime)) {
+ realMap.put("beam", beamMap.get("beam").toString());
+ }
+ }
+ Calendar calendar = Calendar.getInstance();
+ Date endTime = sdf1.parse(rtime);
+ calendar.setTime(endTime);
+ calendar.add(Calendar.HOUR, -6);
+ Date startTime = calendar.getTime();
+ Map<String, Object> hashMap = new HashMap<>();
+ hashMap.put("areaCode", Integer.valueOf(parameters.get("areaCode").toString()));
+ hashMap.put("start", startTime);
+ hashMap.put("end", endTime);
+ hashMap.put("monitorPointId", Integer.valueOf(parameters.get("monitorPointId").toString()));
+ Map<String, Object> precip6HourMap = realWeatherMapper.getPrecip6Hour(hashMap);
+ realMap.put("precip6", precip6HourMap.get("precip6").toString());
}
List<Map<String, Object>> list = new ArrayList<>();
@@ -393,13 +504,18 @@
}
}
}
+
+
list.removeAll(Collections.singleton(null));
+
+
for (Map<String, Object> map : list) {
map.put("type", "������");
map.put("city", parameters.get("city").toString());
}
List<Map<String, Object>> resultList = new ArrayList<>();
+
for (Map<String, Object> foreMap : foreList) {
for (Map<String, Object> realMap : list) {
if (foreMap.get("time").equals(realMap.get("time"))) {
@@ -418,39 +534,65 @@
hashMap.put("city", parameters.get("city").toString());
resultList.add(hashMap);
}
+
+ for (Map<String, Object> map : resultList) {
+ String date = map.get("time").toString().substring(0, 16);
+ map.put("time", date);
+ }
return resultList;
}
@Override
- public void updateForecastWeather(List<Map<String, Object>> list) {
- for (Map<String, Object> map : list) {
- String time = map.get("time").toString();
- Map<String, Object> parameters = new HashMap<>();
- parameters.put("time", time);
- Integer monitorPointId;
- String city = map.get("city").toString();
- Area area = areaMapper.getAreaByName(city);
- if (area == null) {
- Integer cityCode = cityMapper.getCityByName(city).getCityCode();
- monitorPointId = monitorPointMapper.getFirstMonitorPointByCityCode(cityCode).getId();
- } else {
- Integer areaCode = area.getAreaCode();
- monitorPointId = monitorPointMapper.getFirstMonitorPointByAreaCode(areaCode).getId();
- }
- parameters.put("monitorPointId", monitorPointId);
-
- Map<String, Object> jsonMap = new HashMap<>();
- for (String key : map.keySet()) {
- if (!key.equals("city") && !key.equals("time") && !key.equals("type")) {
- String value = map.get(key).toString();
- jsonMap.put(key, value);
+ public void updateForecastWeather(Map<String, Object> parameters) {
+ List<Integer> list = new ArrayList<>();
+ List<Map<String, Object>> resultList = new ArrayList<>();
+ for (int i = 0; i < 48; i++) {
+ list.add(i);
+ resultList.add(null);
+ }
+ for (Integer s : list) {
+ Map<String, Object> map = new HashMap<>();
+ for (String key : parameters.keySet()) {
+ String replace = key.split("\\[")[0];
+ if (replace.equals(s + "")) {
+ String ss = key.split("\\[")[1].replace("]", "");
+ map.put(ss, parameters.get(key).toString());
}
}
+ resultList.set(s, map);
+ }
+ for (Map<String, Object> map : resultList) {
+ if (map.get("type").equals("������")) {
+ String time = map.get("time").toString() + ":00";
+ Map<String, Object> hashMap = new HashMap<>();
+ hashMap.put("time", time);
+ String city = map.get("city").toString();
+ Area area = areaMapper.getAreaByName(city);
+ Map<String, Object> idMap = new HashMap<>();
+ if (area == null) {
+ Integer cityCode = cityMapper.getCityByName(city).getCityCode();
+ idMap.put("cityCode", cityCode);
+ } else {
+ Integer areaCode = area.getAreaCode();
+ idMap.put("areaCode", areaCode);
+ }
- String json = JSONObject.toJSONString(jsonMap);
- parameters.put("json", json);
+ List<MonitorPoint> monitorList = monitorPointMapper.getMonitorList(idMap);
+ Map<String, Object> jsonMap = new HashMap<>();
+ for (String key : map.keySet()) {
+ if (!key.equals("city") && !key.equals("time") && !key.equals("type") && !key.equals("fxTime")) {
+ String value = map.get(key).toString();
+ jsonMap.put(key, value);
+ }
+ }
- forecastWeatherMapper.updateForecastWeather(parameters);
+ String json = JSONObject.toJSONString(jsonMap);
+ hashMap.put("json", json);
+ for (MonitorPoint monitorPoint : monitorList) {
+ hashMap.put("monitorPointId", monitorPoint.getId());
+ forecastWeatherMapper.updateForecastWeather(hashMap);
+ }
+ }
}
}
}
diff --git a/src/main/resources/mapper/DeviceMapper.xml b/src/main/resources/mapper/DeviceMapper.xml
index d2c0b74..6e1dd54 100644
--- a/src/main/resources/mapper/DeviceMapper.xml
+++ b/src/main/resources/mapper/DeviceMapper.xml
@@ -481,5 +481,8 @@
</where>
</select>
-
+ <select id="getDeviceListByMonitorPointIds" resultType="com.moral.entity.Device">
+ select * from device where monitor_point_id in
+ <foreach item="item" collection="list" index="index" open="(" separator="," close=")">#{item}</foreach>
+ </select>
</mapper>
\ No newline at end of file
diff --git a/src/main/resources/mapper/ForecastWeatherMapper.xml b/src/main/resources/mapper/ForecastWeatherMapper.xml
index 8c084fc..2e04576 100644
--- a/src/main/resources/mapper/ForecastWeatherMapper.xml
+++ b/src/main/resources/mapper/ForecastWeatherMapper.xml
@@ -7,7 +7,7 @@
<select id="getForecastHour" resultType="java.util.Map">
SELECT
DATE_FORMAT(time, #{typeFormat}) time,
- (case when result is null then json->'$.tem' else result end) result
+ (case when result is null then json->'$.temp' else result end) result
from forecast_weather
where time >= #{start}
AND time <![CDATA[<]]> #{end}
@@ -30,4 +30,16 @@
where monitor_point_id=#{monitorPointId}
and time=#{time}
</update>
+
+
+ <select id="getPrecip6Hour" resultType="java.util.Map">
+ select
+ round(sum(json->'$.precip'),2) 'precip6'
+ FROM
+ forecast_weather
+ WHERE
+ time >= #{start}
+ AND time <![CDATA[<]]> #{end}
+ AND monitor_point_id = #{monitorPointId}
+ </select>
</mapper>
\ No newline at end of file
diff --git a/src/main/resources/mapper/HangzhouAqiMapper.xml b/src/main/resources/mapper/HangzhouAqiMapper.xml
index 753ed7f..3b0bbb0 100644
--- a/src/main/resources/mapper/HangzhouAqiMapper.xml
+++ b/src/main/resources/mapper/HangzhouAqiMapper.xml
@@ -98,8 +98,8 @@
<select id="getAvgO3EightHours" resultType="java.util.Map">
select
- AVG(aqi_json->'$.O3') 'O3������8������',
- AVG(aqi_json->'$.O3C') 'O3������8������'
+ AVG(aqi_json->'$.O3') 'O3_8H',
+ AVG(aqi_json->'$.O3C') 'O3C_8H'
FROM
hangzhou_aqi
WHERE
diff --git a/src/main/resources/mapper/HistoryHourlyMapper.xml b/src/main/resources/mapper/HistoryHourlyMapper.xml
index b428cba..aa83d96 100644
--- a/src/main/resources/mapper/HistoryHourlyMapper.xml
+++ b/src/main/resources/mapper/HistoryHourlyMapper.xml
@@ -56,10 +56,25 @@
<select id="getTVOCByMac" resultType="java.lang.String">
select json->'$.${sensor}[0]' as e17 from history_hourly where mac=#{mac} and time=#{time}
</select>
+
<select id="getPressureByMac" resultType="java.lang.String">
select json->'$.e28[0]' as e28 from history_hourly where mac=#{mac} and time=#{time}
</select>
+
<select id="getDataByMac" resultType="java.util.Map">
- select json from history_hourly where mac=#{mac} and time=#{time}
+ select json from history_hourly where mac=#{mac} and time=#{time}
+ </select>
+
+ <select id="getBeamByMacs" resultType="java.util.Map">
+ SELECT
+ DATE_FORMAT(h.time,'%Y-%m-%d %H:%i:%s') time,
+ avg(h.json->'$.e12[0]') beam
+ FROM history_hourly h
+ WHERE h.mac in
+ <foreach item="item" collection="macs" index="index" open="(" separator="," close=")">#{item}</foreach>
+ and h.time >= #{start}
+ AND h.time <![CDATA[<]]> #{end}
+ and h.json->'$.e12[0]' is not null
+ group by DATE_FORMAT(h.time,'%Y-%m-%d %H:%i:%s')
</select>
</mapper>
\ No newline at end of file
diff --git a/src/main/resources/mapper/MonitorPointMapper.xml b/src/main/resources/mapper/MonitorPointMapper.xml
index 941d1b8..5e2d6da 100644
--- a/src/main/resources/mapper/MonitorPointMapper.xml
+++ b/src/main/resources/mapper/MonitorPointMapper.xml
@@ -1,186 +1,200 @@
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.moral.mapper.MonitorPointMapper">
- <resultMap id="BaseResultMap" type="com.moral.entity.MonitorPoint">
- <id column="id" jdbcType="INTEGER" property="id" />
- <result column="name" jdbcType="VARCHAR" property="name" />
- <result column="longitude" jdbcType="REAL" property="longitude" />
- <result column="latitude" jdbcType="REAL" property="latitude" />
- <result column="province_code" jdbcType="INTEGER" property="provinceCode" />
- <result column="city_code" jdbcType="INTEGER" property="cityCode" />
- <result column="area_code" jdbcType="INTEGER" property="areaCode" />
- <result column="organization_id" jdbcType="INTEGER" property="organizationId" />
- <result column="address" jdbcType="VARCHAR" property="address" />
- <result column="is_delete" jdbcType="CHAR" property="isDelete" />
- <result column="description" jdbcType="VARCHAR" property="description" />
- <result column="state" jdbcType="INTEGER" property="state" />
- <!-- ������������������������������ -->
- <association property="areaNames" javaType="com.moral.entity.AreaNames">
- <result column="province_name" property="provinceName" jdbcType="VARCHAR" />
- <result column="city_name" property="cityName" jdbcType="VARCHAR" />
- <result column="area_name" property="areaName" jdbcType="VARCHAR" />
- <result column="town_name" property="townName" jdbcType="VARCHAR" />
- <result column="village_name" property="villageName" jdbcType="VARCHAR" />
- </association>
- <association property="organization" javaType="com.moral.entity.Organization">
- <result column="organization_id" property="id" jdbcType="INTEGER" />
- <result column="organization_name" property="name" jdbcType="VARCHAR" />
- </association>
- </resultMap>
- <sql id="Example_Where_Clause">
- <where>
- <foreach collection="oredCriteria" item="criteria" separator="or">
- <if test="criteria.valid">
- <trim prefix="(" prefixOverrides="and" suffix=")">
- <foreach collection="criteria.criteria" item="criterion">
- <choose>
- <when test="criterion.noValue">
- and ${criterion.condition}
- </when>
- <when test="criterion.singleValue">
- and ${criterion.condition} #{criterion.value}
- </when>
- <when test="criterion.betweenValue">
- and ${criterion.condition} #{criterion.value} and #{criterion.secondValue}
- </when>
- <when test="criterion.listValue">
- and ${criterion.condition}
- <foreach close=")" collection="criterion.value" item="listItem" open="(" separator=",">
- #{listItem}
- </foreach>
- </when>
- </choose>
- </foreach>
- </trim>
- </if>
- </foreach>
- </where>
- </sql>
- <sql id="Base_Column_List">
+ <resultMap id="BaseResultMap" type="com.moral.entity.MonitorPoint">
+ <id column="id" jdbcType="INTEGER" property="id"/>
+ <result column="name" jdbcType="VARCHAR" property="name"/>
+ <result column="longitude" jdbcType="REAL" property="longitude"/>
+ <result column="latitude" jdbcType="REAL" property="latitude"/>
+ <result column="province_code" jdbcType="INTEGER" property="provinceCode"/>
+ <result column="city_code" jdbcType="INTEGER" property="cityCode"/>
+ <result column="area_code" jdbcType="INTEGER" property="areaCode"/>
+ <result column="organization_id" jdbcType="INTEGER" property="organizationId"/>
+ <result column="address" jdbcType="VARCHAR" property="address"/>
+ <result column="is_delete" jdbcType="CHAR" property="isDelete"/>
+ <result column="description" jdbcType="VARCHAR" property="description"/>
+ <result column="state" jdbcType="INTEGER" property="state"/>
+ <!-- ������������������������������ -->
+ <association property="areaNames" javaType="com.moral.entity.AreaNames">
+ <result column="province_name" property="provinceName" jdbcType="VARCHAR"/>
+ <result column="city_name" property="cityName" jdbcType="VARCHAR"/>
+ <result column="area_name" property="areaName" jdbcType="VARCHAR"/>
+ <result column="town_name" property="townName" jdbcType="VARCHAR"/>
+ <result column="village_name" property="villageName" jdbcType="VARCHAR"/>
+ </association>
+ <association property="organization" javaType="com.moral.entity.Organization">
+ <result column="organization_id" property="id" jdbcType="INTEGER"/>
+ <result column="organization_name" property="name" jdbcType="VARCHAR"/>
+ </association>
+ </resultMap>
+ <sql id="Example_Where_Clause">
+ <where>
+ <foreach collection="oredCriteria" item="criteria" separator="or">
+ <if test="criteria.valid">
+ <trim prefix="(" prefixOverrides="and" suffix=")">
+ <foreach collection="criteria.criteria" item="criterion">
+ <choose>
+ <when test="criterion.noValue">
+ and ${criterion.condition}
+ </when>
+ <when test="criterion.singleValue">
+ and ${criterion.condition} #{criterion.value}
+ </when>
+ <when test="criterion.betweenValue">
+ and ${criterion.condition} #{criterion.value} and #{criterion.secondValue}
+ </when>
+ <when test="criterion.listValue">
+ and ${criterion.condition}
+ <foreach close=")" collection="criterion.value" item="listItem" open="("
+ separator=",">
+ #{listItem}
+ </foreach>
+ </when>
+ </choose>
+ </foreach>
+ </trim>
+ </if>
+ </foreach>
+ </where>
+ </sql>
+ <sql id="Base_Column_List">
id, name, longitude, latitude, province_code, city_code, area_code, organization_id,
address, is_delete, description
</sql>
- <sql id="Relation_Province_City_Area_List">
+ <sql id="Relation_Province_City_Area_List">
are.area_name, cti.city_name, pro.province_name, t.town_name, v.village_name
</sql>
- <select id="selectWithAreaNameByExample" parameterType="tk.mybatis.mapper.entity.Example" resultMap="BaseResultMap">
- select
- <if test="distinct">
- distinct
- </if>
- mpt.* ,
- org.name as organization_name ,
- <include refid="Relation_Province_City_Area_List" />
- from monitor_point mpt
- left join area are on mpt.area_code = are.area_code
- left join city cti on mpt.city_code = cti.city_code
- left join province pro on mpt.province_code = pro.province_code
- left join organization org on mpt.organization_id = org.id
- left join town t on mpt.town_code = t.town_code
- left join village v on mpt.village_code = v.village_code
+ <select id="selectWithAreaNameByExample" parameterType="tk.mybatis.mapper.entity.Example" resultMap="BaseResultMap">
+ select
+ <if test="distinct">
+ distinct
+ </if>
+ mpt.* ,
+ org.name as organization_name ,
+ <include refid="Relation_Province_City_Area_List"/>
+ from monitor_point mpt
+ left join area are on mpt.area_code = are.area_code
+ left join city cti on mpt.city_code = cti.city_code
+ left join province pro on mpt.province_code = pro.province_code
+ left join organization org on mpt.organization_id = org.id
+ left join town t on mpt.town_code = t.town_code
+ left join village v on mpt.village_code = v.village_code
where mpt.id in (
- select id from monitor_point
- <if test="_parameter != null">
- <include refid="Example_Where_Clause" />
- </if>
- <if test="orderByClause != null">
- order by ${orderByClause}
- </if>
- )
- </select>
- <select id="getMonitorPointsByAreaName" resultMap="BaseResultMap">
- SELECT
- mp.*
- FROM
- monitor_point mp,
- area a
- <if test="cityName != null">
- ,city c
- </if>
- WHERE
- mp.area_code = a.area_code
- AND a.area_name = #{areaName}
- <if test="cityName != null">
- AND c.city_name = #{cityName}
- AND mp.city_code = c.city_code
- </if>
- </select>
- <select id="selectByMap" parameterType="java.util.Map" resultMap="BaseResultMap">
- SELECT mpt.* from monitor_point mpt
- <where>
- <if test="@com.moral.common.bean.Constants@isNotSpecialOrgId(orgId)">
- (
- 1 > 1
- <if test="orgIds!=null and orgIds.size() > 0">
- or mpt.organization_id in
- <foreach collection="orgIds" item="tempOrgId" open="(" close=")" separator=",">
- #{tempOrgId,jdbcType=INTEGER}
- </foreach>
- </if>
- )
- </if>
- <![CDATA[
+ select id from monitor_point
+ <if test="_parameter != null">
+ <include refid="Example_Where_Clause"/>
+ </if>
+ <if test="orderByClause != null">
+ order by ${orderByClause}
+ </if>
+ )
+ </select>
+ <select id="getMonitorPointsByAreaName" resultMap="BaseResultMap">
+ SELECT
+ mp.*
+ FROM
+ monitor_point mp,
+ area a
+ <if test="cityName != null">
+ ,city c
+ </if>
+ WHERE
+ mp.area_code = a.area_code
+ AND a.area_name = #{areaName}
+ <if test="cityName != null">
+ AND c.city_name = #{cityName}
+ AND mp.city_code = c.city_code
+ </if>
+ </select>
+ <select id="selectByMap" parameterType="java.util.Map" resultMap="BaseResultMap">
+ SELECT mpt.* from monitor_point mpt
+ <where>
+ <if test="@com.moral.common.bean.Constants@isNotSpecialOrgId(orgId)">
+ (
+ 1 > 1
+ <if test="orgIds!=null and orgIds.size() > 0">
+ or mpt.organization_id in
+ <foreach collection="orgIds" item="tempOrgId" open="(" close=")" separator=",">
+ #{tempOrgId,jdbcType=INTEGER}
+ </foreach>
+ </if>
+ )
+ </if>
+ <![CDATA[
AND mpt.longitude < #{mapBounds.Ge,jdbcType=NUMERIC}
AND mpt.longitude > #{mapBounds.Le,jdbcType=NUMERIC}
AND mpt.latitude < #{mapBounds.Fe,jdbcType=NUMERIC}
AND mpt.latitude > #{mapBounds.Ke,jdbcType=NUMERIC}
]]>
- <if test="regionCode != null">
- AND mpt.${regionType}_code = #{regionCode}
- </if>
-
- <if test="isDelete != null">
- AND mpt.is_delete = #{isDelete,jdbcType=VARCHAR}
- </if>
- </where>
- </select>
- <select id="selectOrganizationIds" parameterType="integer" resultType="integer">
+ <if test="regionCode != null">
+ AND mpt.${regionType}_code = #{regionCode}
+ </if>
+
+ <if test="isDelete != null">
+ AND mpt.is_delete = #{isDelete,jdbcType=VARCHAR}
+ </if>
+ </where>
+ </select>
+ <select id="selectOrganizationIds" parameterType="integer" resultType="integer">
call proc_organizationIds_GetByMonitorPointId(#{id,jdbcType=NUMERIC})
</select>
- <select id="selectVersionsById" parameterType="integer" resultType="integer">
+ <select id="selectVersionsById" parameterType="integer" resultType="integer">
select version from device_version dve
right join device dev on dve.id = dev.device_version_id
right join monitor_point mpt on mpt.id = dev.monitor_point_id
where mpt.id = #{id} ORDER BY version DESC
</select>
- <select id="selectAllById" resultType="java.util.Map">
+ <select id="selectAllById" resultType="java.util.Map">
SELECT *
FROM monitor_point
WHERE id = #{id}
</select>
- <select id="getIdByOrganizationId" resultType="java.util.Map">
- SELECT id
- FROM monitor_point
- WHERE organization_id IN
- <foreach collection="organizationIdList" index="index" item="organizationId" open="(" separator="," close=")">
- #{organizationId}
- </foreach>
- </select>
+ <select id="getIdByOrganizationId" resultType="java.util.Map">
+ SELECT id
+ FROM monitor_point
+ WHERE organization_id IN
+ <foreach collection="organizationIdList" index="index" item="organizationId" open="(" separator="," close=")">
+ #{organizationId}
+ </foreach>
+ </select>
- <select id="getDeviceList" resultType="com.moral.entity.Device">
+ <select id="getDeviceList" resultType="com.moral.entity.Device">
SELECT d.* FROM `device` as d,monitor_point as mp
where d.monitor_point_id=mp.id
and mp.id=#{id}
</select>
- <select id="getMonitorPointById" resultType="com.moral.entity.MonitorPoint">
+ <select id="getMonitorPointById" resultType="com.moral.entity.MonitorPoint">
select * from monitor_point where id=#{id}
</select>
- <select id="getMonitorPointListByAccountId" resultType="com.moral.entity.MonitorPoint">
+ <select id="getMonitorPointListByAccountId" resultType="com.moral.entity.MonitorPoint">
SELECT mp.* FROM account a,`monitor_point` mp,organization o
where a.organization_id=o.id
and o.id=mp.organization_id
and a.id=#{id};
</select>
- <select id="getFirstMonitorPointByAreaCode" resultType="com.moral.entity.MonitorPoint" resultMap="BaseResultMap">
+ <select id="getFirstMonitorPointByAreaCode" resultType="com.moral.entity.MonitorPoint" resultMap="BaseResultMap">
select * from monitor_point where area_code=#{areaCode} limit 0,1
</select>
- <select id="getFirstMonitorPointByCityCode" resultType="com.moral.entity.MonitorPoint" resultMap="BaseResultMap">
+ <select id="getFirstMonitorPointByCityCode" resultType="com.moral.entity.MonitorPoint" resultMap="BaseResultMap">
select * from monitor_point where city_code=#{cityCode} limit 0,1
</select>
- <select id="getFirstMonitorPointByProvinceCode" resultType="com.moral.entity.MonitorPoint" resultMap="BaseResultMap">
+ <select id="getFirstMonitorPointByProvinceCode" resultType="com.moral.entity.MonitorPoint"
+ resultMap="BaseResultMap">
select * from monitor_point where province_code=#{provinceCode} limit 0,1
</select>
+
+ <select id="getMonitorList" resultMap="BaseResultMap">
+ select * from monitor_point
+ where
+ <if test="areaCode != null">
+ area_Code = #{areaCode}
+ </if>
+
+ <if test="cityCode != null">
+ city_Code = #{cityCode}
+ </if>
+ </select>
</mapper>
\ No newline at end of file
diff --git a/src/main/resources/mapper/RealWeatherMapper.xml b/src/main/resources/mapper/RealWeatherMapper.xml
index ad86d99..80934c3 100644
--- a/src/main/resources/mapper/RealWeatherMapper.xml
+++ b/src/main/resources/mapper/RealWeatherMapper.xml
@@ -17,4 +17,15 @@
ORDER BY
time
</select>
+
+ <select id="getPrecip6Hour" resultType="java.util.Map">
+ select
+ round(sum(json->'$.precip'),2) 'precip6'
+ FROM
+ real_weather
+ WHERE
+ time >= #{start}
+ AND time <![CDATA[<]]> #{end}
+ AND monitor_point_id = #{monitorPointId}
+ </select>
</mapper>
\ No newline at end of file
--
Gitblit v1.8.0