sql >> Base de Datos >  >> RDS >> Mysql

Cómo calcular el porcentaje de dos columnas en MySQL

A veces, es posible que necesite simplemente calcular un porcentaje de dos columnas en las bases de datos MySQL. Aquí se explica cómo calcular fácilmente el porcentaje de dos columnas en MySQL.

Cómo calcular el porcentaje de dos columnas en MySQL

Aquí están los SQL para calcular el porcentaje de dos columnas en MySQL. Supongamos que tiene la siguiente tabla:sales(sales_rep,sale,goal)

mysql> create table sales(sales_rep varchar(255),sale int, goal int);

mysql> insert into sales(sales_rep,sale,goal) 
values('Albert',10,20),('Bob',23,33),('Chris',20,25),('Dave',35,40);

mysql> select * from sales;
+-----------+------+------+
| sales_rep | sale | goal |
+-----------+------+------+
| Albert    |   10 |   20 |
| Bob       |   23 |   33 |
| Chris     |   20 |   25 |
| Dave      |   35 |   40 |
+-----------+------+------+

Supongamos que desea calcular el porcentaje de logro como venta/objetivo*100 para cada representante de ventas.

Aquí está la consulta SQL para calcular el porcentaje de dos columnas (venta, meta). Puede calcularlo directamente sobre la marcha usando operadores de división y multiplicación, como se muestra a continuación.

mysql> select sales_rep,sale,goal,
(sale/goal)*100 as attainment_percent from sales;
+-----------+------+------+--------------------+
| sales_rep | sale | goal | attainment_percent |
+-----------+------+------+--------------------+
| Albert    |   10 |   20 |            50.0000 |
| Bob       |   23 |   33 |            69.6970 |
| Chris     |   20 |   25 |            80.0000 |
| Dave      |   35 |   40 |            87.5000 |
+-----------+------+------+--------------------+

Lectura adicional: Cómo automatizar consultas de tablas dinámicas en MySQL

Si desea redondear los números porcentuales a 2 decimales, puede usar la función REDONDAR como se muestra

mysql> select sales_rep,sale,goal,
round((sale/goal)*100,2) as attainment_percent from sales;
+-----------+------+------+--------------------+
| sales_rep | sale | goal | attainment_percent |
+-----------+------+------+--------------------+
| Albert    |   10 |   20 |              50.00 |
| Bob       |   23 |   33 |              69.70 |
| Chris     |   20 |   25 |              80.00 |
| Dave      |   35 |   40 |              87.50 |
+-----------+------+------+--------------------+

Si desea calcular el porcentaje de dos columnas solo para filas específicas, agregue la cláusula WHERE como se muestra a continuación en negrita

mysql> select sales_rep,sale,goal
,round((sale/goal)*100,2) as attainment_percent
 from sales
 where sales_rep in ('Bob','Dave');
+-----------+------+------+--------------------+
| sales_rep | sale | goal | attainment_percent |
+-----------+------+------+--------------------+
| Bob       |   23 |   33 |              69.70 |
| Dave      |   35 |   40 |              87.50 |
+-----------+------+------+--------------------+

Lectura adicional: Cómo calcular la media móvil en MySQL

Si sus datos totales se distribuyen en varias columnas, como se muestra a continuación,

mysql> create table sales(sales_rep varchar(255),sale int, sale2 int,sale3 int);

mysql> insert into sales(sales_rep,sale,sale2,sale3) 
values('Albert',10,20,10),('Bob',23,33,20),
('Chris',20,25,15),('Dave',35,40,20);

mysql> select * from sales;
+-----------+------+-------+-------+
| sales_rep | sale | sale2 | sale3 |
+-----------+------+-------+-------+
| Albert    |   10 |    20 |    10 |
| Bob       |   23 |    33 |    20 |
| Chris     |   20 |    25 |    15 |
| Dave      |   35 |    40 |    20 |
+-----------+------+-------+-------+

luego puede calcular el porcentaje de cada columna sumando sus valores sobre la marcha, como se muestra a continuación.

mysql> select sales_rep,sale, sale2,sale3, 
(sale/(sale+sale2+sale3))*100 as sale_pct, 
(sale2/(sale+sale2+sale3))*100 as sale2_pct, 
(sale3/(sale+sale2+sale3))*100 as sale3_pct 
from sales;
+-----------+------+-------+-------+----------+-----------+-----------+
| sales_rep | sale | sale2 | sale3 | sale_pct | sale2_pct | sale3_pct |
+-----------+------+-------+-------+----------+-----------+-----------+
| Albert    |   10 |    20 |    10 |  25.0000 |   50.0000 |   25.0000 |
| Bob       |   23 |    33 |    20 |  30.2632 |   43.4211 |   26.3158 |
| Chris     |   20 |    25 |    15 |  33.3333 |   41.6667 |   25.0000 |
| Dave      |   35 |    40 |    20 |  36.8421 |   42.1053 |   21.0526 |
+-----------+------+-------+-------+----------+-----------+-----------+

Puede personalizar la consulta anterior para calcular el porcentaje de dos columnas, según sus requisitos.

También puede usar una herramienta de informes para trazar estos datos en una tabla o tablero y compartirlos con su equipo. Aquí hay un ejemplo de una tabla con los datos anteriores, creada con Ubiq.

Si desea crear gráficos, paneles e informes desde la base de datos MySQL, puede probar Ubiq. Ofrecemos una prueba gratuita de 14 días.