重复数据优化
This commit is contained in:
@@ -840,33 +840,44 @@
|
|||||||
</select>
|
</select>
|
||||||
|
|
||||||
<select id="getNewDeviceFlowStatistics" resultType="LineFlowMealDetailVO">
|
<select id="getNewDeviceFlowStatistics" resultType="LineFlowMealDetailVO">
|
||||||
select t.*,
|
|
||||||
(t.statisValue)/t.flowMeal flowProportion
|
|
||||||
from (
|
|
||||||
SELECT
|
SELECT
|
||||||
device.Name name,
|
ANY_VALUE(t.ID) id,
|
||||||
sub.Name substation,
|
ANY_VALUE(t.name) name,
|
||||||
device.Update_Time updateTime,
|
ANY_VALUE(t.substation) substation,
|
||||||
b.run_flag runFlag,
|
ANY_VALUE(t.updateTime) updateTime,
|
||||||
b.com_flag comFlag,
|
ANY_VALUE(t.runFlag) runFlag,
|
||||||
ifnull(d.flow, (select flow from cld_flow_meal where type = 0 and flag = 1)) + ifnull(d1.flow, 0) flowMeal,
|
ANY_VALUE(t.comFlag) comFlag,
|
||||||
ROUND(ifnull(m.Actual_Value,0)/1024/1024,2) statisValue
|
ANY_VALUE(t.flowMeal) flowMeal,
|
||||||
FROM cld_month_flow m
|
SUM(t.statisValue) statisValue,
|
||||||
INNER JOIN pq_line device ON device.id=m.Dev_Id
|
ROUND(SUM(t.statisValue)/flowMeal,2) flowProportion
|
||||||
INNER JOIN pq_device b ON device.id=b.id
|
from (
|
||||||
INNER JOIN pq_line sub ON device.pid = sub.id
|
SELECT
|
||||||
LEFT JOIN cld_dev_meal c ON b.id = c.line_id
|
device.id id,
|
||||||
LEFT JOIN cld_flow_meal d ON c.Base_Meal_Id = d.id
|
device.Name name,
|
||||||
LEFT JOIN cld_flow_meal d1 ON c.Ream_Meal_Id = d1.id
|
sub.Name substation,
|
||||||
where device.id in
|
device.Update_Time updateTime,
|
||||||
<foreach item="item" collection="devs" separator="," open="(" close=")">
|
b.run_flag runFlag,
|
||||||
#{item}
|
b.com_flag comFlag,
|
||||||
</foreach>
|
ifnull(d.flow, (select flow from cld_flow_meal where type = 0 and flag = 1)) + ifnull(d1.flow, 0) flowMeal,
|
||||||
and
|
ROUND(ifnull(m.Actual_Value,0)/1024/1024,2) statisValue
|
||||||
m.Time_Id between #{startTime} and #{endTime}
|
FROM cld_month_flow m
|
||||||
and
|
INNER JOIN pq_line device ON device.id=m.Dev_Id
|
||||||
b.Run_Flag != 2
|
INNER JOIN pq_device b ON device.id=b.id
|
||||||
) t ORDER BY flowProportion DESC
|
INNER JOIN pq_line sub ON device.pid = sub.id
|
||||||
|
LEFT JOIN cld_dev_meal c ON b.id = c.line_id
|
||||||
|
LEFT JOIN cld_flow_meal d ON c.Base_Meal_Id = d.id
|
||||||
|
LEFT JOIN cld_flow_meal d1 ON c.Ream_Meal_Id = d1.id
|
||||||
|
where device.id in
|
||||||
|
<foreach item="item" collection="devs" separator="," open="(" close=")">
|
||||||
|
#{item}
|
||||||
|
</foreach>
|
||||||
|
and
|
||||||
|
m.Time_Id between #{startTime} and #{endTime}
|
||||||
|
and
|
||||||
|
b.Run_Flag != 2
|
||||||
|
) t
|
||||||
|
GROUP BY t.id
|
||||||
|
ORDER BY flowProportion DESC
|
||||||
</select>
|
</select>
|
||||||
|
|
||||||
<select id="getFlowLineInfoByTableList" resultType="LineFlowMealDetailVO">
|
<select id="getFlowLineInfoByTableList" resultType="LineFlowMealDetailVO">
|
||||||
|
|||||||
@@ -379,10 +379,9 @@ public class LineServiceImpl extends ServiceImpl<LineMapper, Line> implements Li
|
|||||||
@Override
|
@Override
|
||||||
public Page<LineFlowMealDetailVO> getNewDeviceRunStatistics(PqsParam deviceInfoParam) {
|
public Page<LineFlowMealDetailVO> getNewDeviceRunStatistics(PqsParam deviceInfoParam) {
|
||||||
List<String> deviceIndexes = new ArrayList<>();
|
List<String> deviceIndexes = new ArrayList<>();
|
||||||
Page<LineFlowMealDetailVO> page = new Page();
|
|
||||||
List<GeneralDeviceDTO> deviceInfoList = generalDeviceService.getDeviceInfo(deviceInfoParam, null, Stream.of(1).collect(Collectors.toList()));
|
List<GeneralDeviceDTO> deviceInfoList = generalDeviceService.getDeviceInfo(deviceInfoParam, null, Stream.of(1).collect(Collectors.toList()));
|
||||||
deviceInfoList.stream().map(GeneralDeviceDTO::getDeviceIndexes).forEach(deviceIndexes::addAll);
|
deviceInfoList.stream().map(GeneralDeviceDTO::getDeviceIndexes).forEach(deviceIndexes::addAll);
|
||||||
page = lineMapper.getNewDeviceFlowStatistics(
|
Page<LineFlowMealDetailVO> page = lineMapper.getNewDeviceFlowStatistics(
|
||||||
new Page(deviceInfoParam.getPageNum(), deviceInfoParam.getPageSize()),
|
new Page(deviceInfoParam.getPageNum(), deviceInfoParam.getPageSize()),
|
||||||
deviceIndexes,
|
deviceIndexes,
|
||||||
DateUtil.beginOfDay(DateUtil.parse(deviceInfoParam.getSearchBeginTime())),
|
DateUtil.beginOfDay(DateUtil.parse(deviceInfoParam.getSearchBeginTime())),
|
||||||
@@ -392,12 +391,8 @@ public class LineServiceImpl extends ServiceImpl<LineMapper, Line> implements Li
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Page<TopMsgPO> dailyDeviceAbnormalStatistics(PqsParam param) {
|
public Page<TopMsgPO> dailyDeviceAbnormalStatistics(PqsParam param) {
|
||||||
long start = System.currentTimeMillis();
|
|
||||||
Page topMsg = topMsgMapper.getTopMsg(new Page(param.getPageNum(), param.getPageSize()), param.getLineGrade(), DateUtil.beginOfDay(DateUtil.parse(param.getSearchBeginTime())),
|
Page topMsg = topMsgMapper.getTopMsg(new Page(param.getPageNum(), param.getPageSize()), param.getLineGrade(), DateUtil.beginOfDay(DateUtil.parse(param.getSearchBeginTime())),
|
||||||
DateUtil.endOfDay(DateUtil.parse(param.getSearchEndTime())));
|
DateUtil.endOfDay(DateUtil.parse(param.getSearchEndTime())));
|
||||||
long end = System.currentTimeMillis();
|
|
||||||
System.out.println("====================================");
|
|
||||||
System.out.println(end-start);
|
|
||||||
return topMsg;
|
return topMsg;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user