75 lines
2.3 KiB
SQL
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;
|