Mysql
 sql >> Base de Dados >  >> RDS >> Mysql

Porcentagens no MySQL


Usar:
SELECT x.company,
       x.year,
       x.annual_total
       x.annual_total / y.total AS percentage
  FROM (SELECT t.company, 
               YEAR(t.date) as year, 
               COUNT( * ) as annual_total
          FROM TABLE t
         WHERE t.company IN ('Medtronic', 'Private')
      GROUP BY YEAR( t.date ) ) x
  JOIN (SELECT t.company,
               COUNT(*) 'total'
          FROM TABLE t
         WHERE t.company IN ('Medtronic', 'Private')
      GROUP BY t.company) y ON y.company = x.company

Se você quiser a porcentagem com casas decimais específicas, use:
CAST(x.annual_total / y.total AS DECIMAL(2,2)) AS percentage

Verifique se isso fornece a contagem por empresa que você espera:
  SELECT t.company,
         COUNT(*) 'total'
    FROM TABLE t
   WHERE t.company IN ('Medtronic', 'Private')
GROUP BY t.company