sql >> Database teknologi >  >> RDS >> Oracle

Sql - alternativ til MED ... AS

Brug blot betinget aggregering:

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 ;

Jeg skal påpege, at det er endnu nemmere at sætte værdierne på separate rækker:

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


  1. Bestilling af punktafgrænsede numeriske sekvenser (f.eks. versionsnumre)

  2. Overvejelser om kryptering af data i hvile for MariaDB

  3. Gentagelse af rækker baseret på kolonneværdi i hver række

  4. Håndtering af MySQL-replikeringsproblemer ved hjælp af ClusterControl