From 9b85345450e2e194a84679bb6612f58a3124aee8 Mon Sep 17 00:00:00 2001 From: whyclxw <810412026@qq.com> Date: 星期五, 20 六月 2025 08:45:13 +0800 Subject: [PATCH] 预警分析管理-电源告警 --- src/main/java/com/whyc/service/SubTablePageInfoService.java | 135 +++++++++++++++++++++++++++++++++ src/main/java/com/whyc/controller/AlmParamController.java | 11 ++ src/main/java/com/whyc/service/BattRealdataIdService.java | 12 ++- src/main/java/com/whyc/pojo/db_data_history/PwrdevHistorydataId.java | 7 + src/main/java/com/whyc/service/PwrdevAlarmService.java | 66 +++++++++++++++ 5 files changed, 219 insertions(+), 12 deletions(-) diff --git a/src/main/java/com/whyc/controller/AlmParamController.java b/src/main/java/com/whyc/controller/AlmParamController.java index a2bc13e..d0ea906 100644 --- a/src/main/java/com/whyc/controller/AlmParamController.java +++ b/src/main/java/com/whyc/controller/AlmParamController.java @@ -138,9 +138,9 @@ } @GetMapping("getBattHisRealInAlm") - @ApiOperation("棰勮鍒嗘瀽绠$悊-涓诲睘鎬у拰鍒嗘瀽灞炴��") - public Response getBattHisRealInAlm(@RequestParam Integer battgroupId,@RequestParam String startTime,@RequestParam(required = false) Integer almId) throws ParseException, InterruptedException { - return battRealdataIdService.getBattHisRealInAlm(battgroupId,startTime,almId); + @ApiOperation("棰勮鍒嗘瀽绠$悊-鐢垫睜缁勪富灞炴�у拰鍒嗘瀽灞炴��") + public Response getBattHisRealInAlm(@RequestParam Integer battgroupId,@RequestParam String startTime,@RequestParam(required = false) Integer almId,@RequestParam(required = false) Integer intervalTime) throws ParseException, InterruptedException { + return battRealdataIdService.getBattHisRealInAlm(battgroupId,startTime,almId,intervalTime); } @PostMapping("getPwrtAlmAnalyse") @@ -151,4 +151,9 @@ return pwrdevAlarmService.getPwrtAlmAnalyse(dto); } + @GetMapping("getPwrHisRealInAlm") + @ApiOperation("棰勮鍒嗘瀽绠$悊-鐢垫簮涓诲睘鎬у拰鍒嗘瀽灞炴��") + public Response getPwrHisRealInAlm(@RequestParam Integer powerId,@RequestParam String startTime,@RequestParam(required = false) Integer almId,@RequestParam(required = false) Integer intervalTime) throws ParseException, InterruptedException { + return pwrdevAlarmService.getPwrHisRealInAlm(powerId,startTime,almId,intervalTime); + } } \ No newline at end of file diff --git a/src/main/java/com/whyc/pojo/db_data_history/PwrdevHistorydataId.java b/src/main/java/com/whyc/pojo/db_data_history/PwrdevHistorydataId.java index e7bce5d..4df3a48 100644 --- a/src/main/java/com/whyc/pojo/db_data_history/PwrdevHistorydataId.java +++ b/src/main/java/com/whyc/pojo/db_data_history/PwrdevHistorydataId.java @@ -40,6 +40,13 @@ @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss",timezone = "Asia/Shanghai") private Date recordDatetime; + @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss",timezone = "Asia/Shanghai") + @TableField(exist = false) + private Date recordDatetime1; + + @TableField(exist = false) + private String tableName; + @ApiModelProperty(value = "缂栧彿") private Integer recordNum; diff --git a/src/main/java/com/whyc/service/BattRealdataIdService.java b/src/main/java/com/whyc/service/BattRealdataIdService.java index 8a1faed..5c057de 100644 --- a/src/main/java/com/whyc/service/BattRealdataIdService.java +++ b/src/main/java/com/whyc/service/BattRealdataIdService.java @@ -227,13 +227,18 @@ return new Response().set(1, dataListSorted); } //鐢垫睜鍛婅鐐瑰嚮鍏蜂綋鍛婅淇℃伅鏌ョ湅浠庡憡璀﹀紑濮嬫椂闂村埌鐜板湪鐨勫巻鍙插疄鏃舵暟鎹� - public Response getBattHisRealInAlm(Integer battgroupId, String startTime, Integer almId) throws ParseException, InterruptedException { + public Response getBattHisRealInAlm(Integer battgroupId, String startTime, Integer almId,Integer intervalTime) throws ParseException, InterruptedException { //鑾峰彇鍛婅almId瀵瑰簲鐨勫垎鏋愰厤缃睘鎬у�� AlmAnalysisParam almAnalysisParam= almAnalysisParamService.getAnalysisParam(almId); List<RealDateDTO> dataList = new LinkedList<>(); + Integer cycleTime=0; //鑾峰彇棰勮鍒嗘瀽鍛ㄦ湡闃堝�� - AppParam appParam = appParamService.getAlarmAnalysisCycle(); - Integer cycleTime=appParam.getParamValue().intValue(); + if(intervalTime==null){ + AppParam appParam = appParamService.getAlarmAnalysisCycle(); + cycleTime=appParam.getParamValue().intValue(); + }else{ + cycleTime=intervalTime; + } Date cyscleDate=ActionUtil.getDateAdd(ThreadLocalUtil.parse(startTime,1),cycleTime*(-1)); //鑾峰彇cyscleDate鍒扮幇鍦ㄦ墍鏈夌殑鍘嗗彶瀹炴椂鏁版嵁 List<List<Date>> monthTimeList = DateUtil.getMonthTime(cyscleDate,new Date()); @@ -262,6 +267,5 @@ latch.await(10, TimeUnit.MINUTES); List dataListSorted = dataList.stream().sorted(Comparator.comparing(RealDateDTO::getRecordTime)).collect(Collectors.toList()); return new Response().setIII(1,true, dataListSorted,almAnalysisParam,"鐢垫睜鍛婅鐐瑰嚮鍏蜂綋鍛婅淇℃伅鏌ョ湅浠庡憡璀﹀紑濮嬫椂闂村埌鐜板湪鐨勫巻鍙插疄鏃舵暟鎹�"); - } } \ No newline at end of file diff --git a/src/main/java/com/whyc/service/PwrdevAlarmService.java b/src/main/java/com/whyc/service/PwrdevAlarmService.java index 2c6c0e8..94aed4f 100644 --- a/src/main/java/com/whyc/service/PwrdevAlarmService.java +++ b/src/main/java/com/whyc/service/PwrdevAlarmService.java @@ -10,26 +10,44 @@ import com.whyc.dto.AlarmDto; import com.whyc.dto.Param.AlmAnalyseDto; import com.whyc.dto.Real.AlmDto; +import com.whyc.dto.Real.RealDateDTO; import com.whyc.dto.Response; +import com.whyc.factory.ThreadPoolExecutorFactory; import com.whyc.mapper.PwrdevAlarmMapper; import com.whyc.pojo.db_alarm.DevalarmData; +import com.whyc.pojo.db_data_history.BattRealdataId; +import com.whyc.pojo.db_data_history.PwrdevHistorydataId; +import com.whyc.pojo.db_param.AlmAnalysisParam; +import com.whyc.pojo.db_param.AppParam; import com.whyc.pojo.db_pwrdev_alarm.PwrdevAlarm; import com.whyc.pojo.db_pwrdev_alarm.PwrdevAlarmParam; import com.whyc.pojo.web_site.AlarmInspection; import com.whyc.util.ActionUtil; +import com.whyc.util.DateUtil; +import com.whyc.util.ThreadLocalUtil; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; +import java.text.ParseException; import java.text.SimpleDateFormat; -import java.util.Date; -import java.util.List; -import java.util.Map; +import java.util.*; +import java.util.concurrent.CountDownLatch; +import java.util.concurrent.ThreadPoolExecutor; +import java.util.concurrent.TimeUnit; import java.util.stream.Collectors; + +import static java.lang.Thread.sleep; @Service public class PwrdevAlarmService { @Autowired(required = false) private PwrdevAlarmMapper mapper; + @Autowired + private AppParamService appParamService; + @Autowired + private AlmAnalysisParamService almAnalysisParamService; + @Autowired + private SubTablePageInfoService subTablePageInfoService; //鑾峰彇鐢垫簮瀹炴椂鍛婅淇℃伅 public Response getPwrAlmReal(AlmDto almDto) { PageHelper.startPage(almDto.getPageNum(),almDto.getPageSize()); @@ -94,4 +112,46 @@ PageInfo pageInfo=new PageInfo(list); return new Response().setII(1,list!=null,pageInfo,"鐢垫簮鍛婅鍒嗘瀽"); } + //棰勮鍒嗘瀽绠$悊-鐢垫簮涓诲睘鎬у拰鍒嗘瀽灞炴�� + public Response getPwrHisRealInAlm(Integer powerId, String startTime, Integer almId,Integer intervalTime) throws ParseException, InterruptedException { + //鑾峰彇鍛婅almId瀵瑰簲鐨勫垎鏋愰厤缃睘鎬у�� + AlmAnalysisParam almAnalysisParam= almAnalysisParamService.getAnalysisParam(almId); + List<PwrdevHistorydataId> dataList = new LinkedList<>(); + Integer cycleTime=0; + //鑾峰彇棰勮鍒嗘瀽鍛ㄦ湡闃堝�� + if(intervalTime==null){ + AppParam appParam = appParamService.getAlarmAnalysisCycle(); + cycleTime=appParam.getParamValue().intValue(); + }else{ + cycleTime=intervalTime; + } + Date cyscleDate=ActionUtil.getDateAdd(ThreadLocalUtil.parse(startTime,1),cycleTime*(-1)); + //鑾峰彇cyscleDate鍒扮幇鍦ㄦ墍鏈夌殑鍘嗗彶瀹炴椂鏁版嵁 + List<List<Date>> monthTimeList = DateUtil.getMonthTime(cyscleDate,new Date()); + ThreadPoolExecutor pool = ThreadPoolExecutorFactory.getPoolExecutor(); + CountDownLatch latch = new CountDownLatch(monthTimeList.size()); + for (int i = 0; i < monthTimeList.size(); i++) { + int finalI = i; + pool.execute(() -> { + int finalII = finalI; + PwrdevHistorydataId pwrHis = new PwrdevHistorydataId(); + pwrHis.setRecordDatetime(monthTimeList.get(finalII).get(0)); + pwrHis.setRecordDatetime1(monthTimeList.get(finalII).get(1)); + String table = powerId + "_" + ThreadLocalUtil.format(pwrHis.getRecordDatetime(),2); + pwrHis.setTableName(table);//琛ㄥ悕鏃堕棿鏍煎紡閮ㄥ垎 + //鍒ゆ柇琛ㄦ槸鍚﹀瓨鍦� + int tableNum = subTablePageInfoService.judgeTable_pwrhis(table); + List<PwrdevHistorydataId> list = new ArrayList(); + if (tableNum > 0) { + list = subTablePageInfoService.getPwrHisRealInAlm(pwrHis); + } + dataList.addAll(list); + latch.countDown(); + }); + sleep(200); + } + latch.await(10, TimeUnit.MINUTES); + List dataListSorted = dataList.stream().sorted(Comparator.comparing(PwrdevHistorydataId::getRecordDatetime)).collect(Collectors.toList()); + return new Response().setIII(1,true, dataListSorted,almAnalysisParam,"棰勮鍒嗘瀽绠$悊-鐢垫簮涓诲睘鎬у拰鍒嗘瀽灞炴��"); + } } \ No newline at end of file diff --git a/src/main/java/com/whyc/service/SubTablePageInfoService.java b/src/main/java/com/whyc/service/SubTablePageInfoService.java index e27caac..ee97944 100644 --- a/src/main/java/com/whyc/service/SubTablePageInfoService.java +++ b/src/main/java/com/whyc/service/SubTablePageInfoService.java @@ -717,7 +717,7 @@ }); return list; } - //鍒ゆ柇鍘嗗彶瀹炴椂琛ㄦ槸鍚﹀瓨鍦� + //鍒ゆ柇鐢垫睜缁勫巻鍙插疄鏃惰〃鏄惁瀛樺湪 public int judgeTable_realdata( String table){ String sql="select count(*) as tableNum " + " from INFORMATION_SCHEMA.TABLES " + @@ -742,7 +742,31 @@ } return tableNum; } - + //鍒ゆ柇鐢垫簮鍘嗗彶瀹炴椂琛ㄦ槸鍚﹀瓨鍦� + public int judgeTable_pwrhis( String table){ + String sql="select count(*) as tableNum " + + " from INFORMATION_SCHEMA.TABLES " + + " where TABLE_SCHEMA = 'db_data_history' " + + " and TABLE_NAME = 'tb_pwrdev_historydata_"+table+"'"; + List list = sqlExecuteService.executeQuery_call(sql, new CallBack() { + @Override + public List getResults(ResultSet rs) throws SQLException { + LinkedList<Object> temp = new LinkedList<>(); + try { + while (rs.next()) + temp.add(rs.getInt("tableNum")); + } catch (SQLException e) { + e.printStackTrace(); + } + return temp; + } + }); + int tableNum =0; + if(list!=null){ + tableNum= (int) list.get(0); + } + return tableNum; + } //鐢垫睜鏁版嵁鍘嗗彶瀹炴椂澶勭悊 public List<RealDateDTO> getBattRealDataHis(BattRealdataId realdata, int granularity,Integer maxRecordNum,Integer minRecordNum) { String sql=" select record_time, group_vol, online_vol,group_curr, mon_vol, mon_tmp, mon_res, mon_num,record_num " + @@ -801,6 +825,113 @@ }); return list; } + + //鐢垫簮鏁版嵁鍘嗗彶瀹炴椂澶勭悊(棰勮鍒嗘瀽) + public List<PwrdevHistorydataId> getPwrHisRealInAlm(PwrdevHistorydataId pwrHis) { + String sql=" select record_time, group_vol, online_vol,group_curr, mon_vol, mon_tmp, mon_res, mon_num,record_num " + + " from db_data_history.tb_batt_realdata_"+pwrHis.getTableName()+" " + + " where record_time >= '"+ThreadLocalUtil.format(pwrHis.getRecordDatetime(),1)+"' " + + " and record_time <= '"+ThreadLocalUtil.format(pwrHis.getRecordDatetime1(),1)+"' " + + " order by record_time asc,mon_num asc"; + List<PwrdevHistorydataId> list = sqlExecuteService.executeQuery_call(sql, new CallBack() { + @Override + public List getResults(ResultSet rs) throws SQLException { + List<PwrdevHistorydataId> list=new ArrayList<>(); + while (rs.next()){ + PwrdevHistorydataId data=new PwrdevHistorydataId(); + data.setRecordDatetime(rs.getTimestamp("record_datetime")); + data.setAcin1Vola(rs.getFloat("acin1_vola")); + data.setAcin1Volb(rs.getFloat("acin1_volb")); + data.setAcin1Volc(rs.getFloat("acin1_volc")); + data.setAcin2Vola(rs.getFloat("acin2_vola")); + data.setAcin2Volb(rs.getFloat("acin2_volb")); + data.setAcin2Volc(rs.getFloat("acin2_volc")); + data.setAcoutVola(rs.getFloat("acout_vola")); + data.setAcoutVolb(rs.getFloat("acout_volb")); + data.setAcoutVolc(rs.getFloat("acout_volc")); + data.setAcoutCurra(rs.getFloat("acout_curra")); + data.setAcoutCurrb(rs.getFloat("acout_currb")); + data.setAcoutCurrc(rs.getFloat("acout_currc")); + data.setDcoutVol(rs.getFloat("dcout_vol")); + data.setDcoutCurr(rs.getFloat("dcout_curr")); + + data.setBattgroup1Vol(rs.getFloat("battgroup1_vol")); + data.setBattgroup1Curr(rs.getFloat("battgroup1_curr")); + data.setBattgroup2Vol(rs.getFloat("battgroup2_vol")); + data.setBattgroup2Curr(rs.getFloat("battgroup2_curr")); + data.setTemprature(rs.getFloat("temprature")); + data.setMOutputvol(rs.getFloat("m_outputvol")); + data.setM1Outcurr(rs.getFloat("m1_outcurr")); + data.setM2Outcurr(rs.getFloat("m2_outcurr")); + data.setM3Outcurr(rs.getFloat("m3_outcurr")); + data.setM4Outcurr(rs.getFloat("m4_outcurr")); + data.setM5Outcurr(rs.getFloat("m5_outcurr")); + data.setM6Outcurr(rs.getFloat("m6_outcurr")); + data.setM7Outcurr(rs.getFloat("m7_outcurr")); + data.setM8Outcurr(rs.getFloat("m8_outcurr")); + data.setM9Outcurr(rs.getFloat("m9_outcurr")); + data.setM10Outcurr(rs.getFloat("m10_outcurr")); + data.setM11Outcurr(rs.getFloat("m11_outcurr")); + data.setM12Outcurr(rs.getFloat("m12_outcurr")); + data.setM13Outcurr(rs.getFloat("m13_outcurr")); + data.setM14Outcurr(rs.getFloat("m14_outcurr")); + data.setM15Outcurr(rs.getFloat("m15_outcurr")); + data.setM16Outcurr(rs.getFloat("m16_outcurr")); + + data.setAcin1Curra(rs.getFloat("acin1_curra")); + data.setAcin1Currb(rs.getFloat("acin1_currb")); + data.setAcin1Currc(rs.getFloat("acin1_currc")); + data.setLoaderCurr(rs.getFloat("loader_curr")); + data.setBattgroup1Ah(rs.getFloat("battgroup1_ah")); + data.setBattgroup1Temp(rs.getFloat("battgroup1_temp")); + data.setBattgroup2Ah(rs.getFloat("battgroup2_ah")); + data.setBattgroup2Temp(rs.getFloat("battgroup2_temp")); + data.setAcdcmTemp(rs.getFloat("acdcm_temp")); + data.setM1OutVol(rs.getFloat("m1_out_vol")); + data.setM2OutVol(rs.getFloat("m2_out_vol")); + data.setM3OutVol(rs.getFloat("m3_out_vol")); + data.setM4OutVol(rs.getFloat("m4_out_vol")); + data.setM5OutVol(rs.getFloat("m5_out_vol")); + data.setM6OutVol(rs.getFloat("m6_out_vol")); + data.setM7OutVol(rs.getFloat("m7_out_vol")); + data.setM8OutVol(rs.getFloat("m8_out_vol")); + data.setM9OutVol(rs.getFloat("m9_out_vol")); + data.setM10OutVol(rs.getFloat("m10_out_vol")); + data.setM11OutVol(rs.getFloat("m11_out_vol")); + data.setM12OutVol(rs.getFloat("m12_out_vol")); + data.setM13OutVol(rs.getFloat("m13_out_vol")); + data.setM14OutVol(rs.getFloat("m14_out_vol")); + data.setM15OutVol(rs.getFloat("m15_out_vol")); + data.setM16OutVol(rs.getFloat("m16_out_vol")); + + data.setUseracin1Vola(rs.getFloat("useracin1_vola")); + data.setUseracin1Volb(rs.getFloat("useracin1_volb")); + data.setUseracin1Volc(rs.getFloat("useracin1_volc")); + data.setUseracin1Curra(rs.getFloat("useracin1_curra")); + data.setUseracin1Currb(rs.getFloat("useracin1_currb")); + data.setUseracin1Currc(rs.getFloat("useracin1_currc")); + data.setUseracin1Freq(rs.getFloat("useracin1_freq")); + data.setUseracin2Vola(rs.getFloat("useracin2_vola")); + data.setUseracin2Volb(rs.getFloat("useracin2_volb")); + data.setUseracin2Volc(rs.getFloat("useracin2_volc")); + data.setUseracin2Curra(rs.getFloat("useracin2_curra")); + data.setUseracin2Currb(rs.getFloat("useracin2_currb")); + data.setUseracin2Currc(rs.getFloat("useracin2_currc")); + data.setUseracin2Freq(rs.getFloat("useracin2_freq")); + + data.setMTemper1(rs.getFloat("m_temper1")); + data.setMTemper2(rs.getFloat("m_temper2")); + data.setMTemper3(rs.getFloat("m_temper3")); + data.setMHumidity1(rs.getFloat("m_humidity1")); + data.setMHumidity2(rs.getFloat("m_humidity2")); + data.setMHumidity3(rs.getFloat("m_humidity3")); + list.add(data); + } + return list; + } + }); + return list; + } //鑾峰彇鎸囧畾鏃堕棿娈靛唴鏈�澶ф渶灏弐ecordNum纭繚鏁版嵁鐨勫畬鏁� public List getMaxAndMinRecordNum(BattRealdataId realdata) { String sql="select max(record_num) as maxRecordNum,min(record_num) as minRecordNum " + -- Gitblit v1.9.1