I made three selects below where each one returns a value. How do I do a select only and return the three values, each with its condition? All information is in one table.
SELECT COUNT (GRA_HRFIM) as "Conferidos antes 17h" FROM GRADE WHERE GRA_HRFIM < '17:00:00' AND GRA_DATADIGITA = '04/28/2021'
SELECT COUNT (GRA_HORADIGITA) as "Importados antes 17h" FROM GRADE WHERE GRA_HORADIGITA < '17:00:00' AND GRA_DATADIGITA = '04/28/2021'
SELECT COUNT (GRA_HRFIM) as "Total pedidos" FROM GRADE WHERE GRA_DATADIGITA = '04/28/2021'
Condition GRA_DATADIGITA = '04/28/2021' is same for all the counts so use it in where clause. Now you have third count by simply selecting COUNT (GRA_HRFIM) but for the first and second count you need to use case when statement to select conditional count.
SELECT COUNT(case when GRA_HRFIM < '17:00:00' then GRA_HRFIM else null end)
AS "Conferidos antes 17h",
COUNT(case when GRA_HORADIGITA < '17:00:00' then GRA_HORADIGITA else null end)
AS "Importados antes 17h",
COUNT(GRA_HRFIM)
AS "Total pedidos"
FROM GRADE
WHERE GRA_DATADIGITA = '04/28/2021';
You can also avoid mentioning else part of case when statements since default value is null.
SELECT COUNT(case when GRA_HRFIM < '17:00:00' then GRA_HRFIM end)
AS "Conferidos antes 17h",
COUNT(case when GRA_HORADIGITA < '17:00:00' then GRA_HORADIGITA end)
AS "Importados antes 17h",
COUNT(GRA_HRFIM)
AS "Total pedidos"
FROM GRADE
WHERE GRA_DATADIGITA = '04/28/2021';
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With