Mysql
 sql >> Base de données >  >> RDS >> Mysql

Pourcentages dans MySQL

Utiliser :

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

Si vous voulez le pourcentage avec des décimales particulières, utilisez :

CAST(x.annual_total / y.total AS DECIMAL(2,2)) AS percentage

Vérifiez que cela donne le nombre par entreprise que vous attendez :

  SELECT t.company,
         COUNT(*) 'total'
    FROM TABLE t
   WHERE t.company IN ('Medtronic', 'Private')
GROUP BY t.company