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