sql >> Database >  >> RDS >> Oracle

Sql - alternatief voor WITH ... AS

Gebruik gewoon voorwaardelijke aggregatie:

SELECT SUM(CASE WHEN STATUS = 'A' THEN 1 ELSE 0 END) AS A_COUNT ,
       SUM(CASE WHEN STATUS = 'B' THEN 1 ELSE 0 END) AS B_COUNT ,
       SUM(CASE WHEN STATUS = 'C' THEN 1 ELSE 0 END) AS C_COUNT ,
       SUM(CASE WHEN STATUS = 'D' THEN 1 ELSE 0 END) AS D_COUNT ,
       SUM(CASE WHEN STATUS = 'E' THEN 1 ELSE 0 END) AS E_COUNT ,
       SUM(CASE WHEN STATUS = 'F' THEN 1 ELSE 0 END) AS F_COUNT 
FROM XYZ ;

Ik moet erop wijzen dat het nog makkelijker is om de waarden op aparte rijen te zetten:

select status, count(*)
from xyz
group by status;


  1. Het belang van onderhoud op MSDB

  2. PDO-gooifout als MYSQL_ATTR_INIT_COMMAND wordt gebruikt

  3. Hoe kan ik een tabel van een opgeslagen procedure naar een gegevenstabel ophalen?

  4. mysql join tabel query 2 waarden