2025-12-01 16:33:11 +04:00

75 lines
2.3 KiB
SQL

SELECT
'S03' AS Sorter,
DATE_FORMAT(:starttime, '%Y-%m-%d %H:%i') AS start_time,
DATE_FORMAT(:endtime, '%Y-%m-%d %H:%i') AS end_time,
'S03aa' AS sScanner_Name,
-- Bad Reads (rate)
CASE
WHEN TIMESTAMPDIFF(SECOND, :starttime, :endtime) = 0 THEN 0
ELSE ROUND(
COALESCE(sorter_total.total_bad_reads, 0) * 3600.0 /
TIMESTAMPDIFF(SECOND, :starttime, :endtime),
2)
END AS total_bad_reads,
-- Good Reads (rate)
CASE
WHEN TIMESTAMPDIFF(SECOND, :starttime, :endtime) = 0 THEN 0
ELSE ROUND(
COALESCE(sorter_total.total_good_reads, 0) * 3600.0 /
TIMESTAMPDIFF(SECOND, :starttime, :endtime),
2)
END AS total_good_reads,
-- Multi Reads (rate)
CASE
WHEN TIMESTAMPDIFF(SECOND, :starttime, :endtime) = 0 THEN 0
ELSE ROUND(
COALESCE(sorter_total.total_multi_reads, 0) * 3600.0 /
TIMESTAMPDIFF(SECOND, :starttime, :endtime),
2)
END AS total_multi_reads,
-- No Data (rate)
CASE
WHEN TIMESTAMPDIFF(SECOND, :starttime, :endtime) = 0 THEN 0
ELSE ROUND(
COALESCE(sorter_total.total_no_data, 0) * 3600.0 /
TIMESTAMPDIFF(SECOND, :starttime, :endtime),
2)
END AS total_no_data,
-- No Reads (rate)
CASE
WHEN TIMESTAMPDIFF(SECOND, :starttime, :endtime) = 0 THEN 0
ELSE ROUND(
COALESCE(sorter_total.total_no_reads, 0) * 3600.0 /
TIMESTAMPDIFF(SECOND, :starttime, :endtime),
2)
END AS total_no_reads,
-- Total Items (rate)
CASE
WHEN TIMESTAMPDIFF(SECOND, :starttime, :endtime) = 0 THEN 0
ELSE ROUND(
COALESCE(sorter_total.total, 0) * 3600.0 /
TIMESTAMPDIFF(SECOND, :starttime, :endtime),
2)
END AS total
FROM (SELECT 1) AS p
LEFT JOIN (
SELECT
SUM(adiSort_Code_0 NOT IN (0, 8, 9, 10, 11, 15)) AS total_bad_reads,
SUM(adiSort_Code_0 = 0) AS total_good_reads,
SUM(adiSort_Code_0 = 10) AS total_multi_reads,
SUM(adiSort_Code_0 = 9) AS total_no_data,
SUM(adiSort_Code_0 = 8) AS total_no_reads,
COUNT(*) AS total
FROM item_data
WHERE t_stamp BETWEEN :starttime AND :endtime
AND adiSort_Code_0 NOT IN (11, 15)
AND sLocation_ID LIKE 'S03%'
) AS sorter_total ON 1 = 1;