|
|
|
|
@ -111,4 +111,97 @@
|
|
|
|
|
) WHERE rn = 1
|
|
|
|
|
) WHERE row_num <= 200
|
|
|
|
|
</select>
|
|
|
|
|
|
|
|
|
|
<!-- 设备状态统计:基于三色灯参数获取设备运行状态统计 -->
|
|
|
|
|
<select id="selectDeviceStatusStatistics" resultType="java.util.Map">
|
|
|
|
|
WITH today_latest AS (
|
|
|
|
|
SELECT
|
|
|
|
|
device_code,
|
|
|
|
|
param_name,
|
|
|
|
|
ROW_NUMBER() OVER (PARTITION BY device_code ORDER BY NVL(record_time, collect_time) DESC) AS rn
|
|
|
|
|
FROM base_device_param_val
|
|
|
|
|
WHERE TRUNC(collect_time) = TRUNC(SYSDATE)
|
|
|
|
|
AND param_name IN ('机台状态-三色灯机器运行', '机台状态-三色灯机器暂停', '机台状态-三色灯机器待机')
|
|
|
|
|
),
|
|
|
|
|
device_status AS (
|
|
|
|
|
SELECT device_code, param_name FROM today_latest WHERE rn = 1
|
|
|
|
|
),
|
|
|
|
|
status_sum AS (
|
|
|
|
|
SELECT
|
|
|
|
|
NVL(SUM(CASE WHEN param_name = '机台状态-三色灯机器运行' THEN 1 ELSE 0 END), 0) AS runningCount,
|
|
|
|
|
NVL(SUM(CASE WHEN param_name = '机台状态-三色灯机器暂停' THEN 1 ELSE 0 END), 0) AS stoppedCount,
|
|
|
|
|
NVL(SUM(CASE WHEN param_name = '机台状态-三色灯机器待机' THEN 1 ELSE 0 END), 0) AS standbyCount
|
|
|
|
|
FROM device_status
|
|
|
|
|
),
|
|
|
|
|
total_cnt AS (
|
|
|
|
|
SELECT COUNT(1) AS totalCount FROM base_deviceledger WHERE is_flag = 1
|
|
|
|
|
)
|
|
|
|
|
SELECT
|
|
|
|
|
t.totalCount,
|
|
|
|
|
s.runningCount,
|
|
|
|
|
s.stoppedCount,
|
|
|
|
|
s.standbyCount,
|
|
|
|
|
t.totalCount - s.runningCount - s.stoppedCount - s.standbyCount AS notStartedCount
|
|
|
|
|
FROM status_sum s, total_cnt t
|
|
|
|
|
</select>
|
|
|
|
|
|
|
|
|
|
<!-- 获取每个设备的编号、名称、三色灯状态 -->
|
|
|
|
|
<select id="selectDeviceStatusList" resultType="java.util.Map">
|
|
|
|
|
WITH today_latest AS (
|
|
|
|
|
SELECT
|
|
|
|
|
device_code,
|
|
|
|
|
param_name,
|
|
|
|
|
ROW_NUMBER() OVER (PARTITION BY device_code ORDER BY NVL(record_time, collect_time) DESC) AS rn
|
|
|
|
|
FROM base_device_param_val
|
|
|
|
|
WHERE TRUNC(collect_time) = TRUNC(SYSDATE)
|
|
|
|
|
AND param_name IN ('机台状态-三色灯机器运行', '机台状态-三色灯机器暂停', '机台状态-三色灯机器待机')
|
|
|
|
|
),
|
|
|
|
|
device_status AS (
|
|
|
|
|
SELECT device_code, param_name FROM today_latest WHERE rn = 1
|
|
|
|
|
)
|
|
|
|
|
SELECT
|
|
|
|
|
d.device_code AS deviceCode,
|
|
|
|
|
d.device_name AS deviceName,
|
|
|
|
|
d.product_line_code AS productLineCode,
|
|
|
|
|
CASE
|
|
|
|
|
WHEN s.param_name = '机台状态-三色灯机器运行' THEN '运行'
|
|
|
|
|
WHEN s.param_name = '机台状态-三色灯机器暂停' THEN '停机'
|
|
|
|
|
WHEN s.param_name = '机台状态-三色灯机器待机' THEN '待机'
|
|
|
|
|
ELSE '未开机'
|
|
|
|
|
END AS deviceStatus,
|
|
|
|
|
CASE
|
|
|
|
|
WHEN s.param_name = '机台状态-三色灯机器运行' THEN 1
|
|
|
|
|
WHEN s.param_name = '机台状态-三色灯机器暂停' THEN 2
|
|
|
|
|
WHEN s.param_name = '机台状态-三色灯机器待机' THEN 3
|
|
|
|
|
ELSE 0
|
|
|
|
|
END AS statusCode
|
|
|
|
|
FROM base_deviceledger d
|
|
|
|
|
LEFT JOIN device_status s ON d.device_code = s.device_code
|
|
|
|
|
WHERE d.is_flag = 1
|
|
|
|
|
ORDER BY d.product_line_code, d.device_code
|
|
|
|
|
</select>
|
|
|
|
|
|
|
|
|
|
<!-- 获取每个设备的开机时间当天最新值 -->
|
|
|
|
|
<select id="selectDeviceStartTimeList" resultType="java.util.Map">
|
|
|
|
|
WITH today_latest AS (
|
|
|
|
|
SELECT
|
|
|
|
|
device_code,
|
|
|
|
|
param_value,
|
|
|
|
|
collect_time,
|
|
|
|
|
ROW_NUMBER() OVER (PARTITION BY device_code ORDER BY NVL(record_time, collect_time) DESC) AS rn
|
|
|
|
|
FROM base_device_param_val
|
|
|
|
|
WHERE TRUNC(collect_time) = TRUNC(SYSDATE)
|
|
|
|
|
AND param_name = '机台状态-开机时间'
|
|
|
|
|
)
|
|
|
|
|
SELECT
|
|
|
|
|
d.device_code AS deviceCode,
|
|
|
|
|
d.device_name AS deviceName,
|
|
|
|
|
d.product_line_code AS productLineCode,
|
|
|
|
|
t.param_value AS startTime,
|
|
|
|
|
t.collect_time AS collectTime
|
|
|
|
|
FROM base_deviceledger d
|
|
|
|
|
LEFT JOIN today_latest t ON d.device_code = t.device_code AND t.rn = 1
|
|
|
|
|
WHERE d.is_flag = 1
|
|
|
|
|
ORDER BY d.product_line_code, d.device_code
|
|
|
|
|
</select>
|
|
|
|
|
</mapper>
|