A veces, es posible que necesite obtener datos por hora o buscar registros para cada hora en MySQL. En este artículo, veremos cómo obtener datos para cada hora en MySQL.
Cómo obtener datos por cada hora en MySQL
Estos son los pasos para obtener datos por cada hora en MySQL. Digamos que tiene la siguiente tabla ventas (id, order_date, cantidad)
mysql> create table sales(id int, order_date datetime, amount int); mysql> insert into sales(id, order_date, amount) values(1, '2021-02-02 08:15:00',250), (2, '2021-02-02 08:30:00',200), (3, '2021-02-02 08:55:00',150), (4, '2021-02-02 09:15:00',125), (5, '2021-02-02 09:30:00',250), (6, '2021-02-02 09:45:00',200), (7, '2021-02-02 10:15:00',180), (8, '2021-02-02 10:30:00',125), (9, '2021-02-02 10:45:00',200), (10, '2021-02-02 11:15:00',250), (11, '2021-02-02 11:30:00',150), (12, '2021-02-02 11:45:00',200); mysql> select * from sales; +------+---------------------+--------+ | id | order_date | amount | +------+---------------------+--------+ | 1 | 2021-02-02 08:15:00 | 250 | | 2 | 2021-02-02 08:30:00 | 200 | | 3 | 2021-02-02 08:55:00 | 150 | | 4 | 2021-02-02 09:15:00 | 125 | | 5 | 2021-02-02 09:30:00 | 250 | | 6 | 2021-02-02 09:45:00 | 200 | | 7 | 2021-02-02 10:15:00 | 180 | | 8 | 2021-02-02 10:30:00 | 125 | | 9 | 2021-02-02 10:45:00 | 200 | | 10 | 2021-02-02 11:15:00 | 250 | | 11 | 2021-02-02 11:30:00 | 150 | | 12 | 2021-02-02 11:45:00 | 200 | +------+---------------------+--------+
Cómo obtener datos por cada hora en MySQL
Aquí está la consulta SQL para obtener datos por cada hora en MySQL.
mysql> select hour(order_date),sum(amount) from sales group by hour(order_date); +------------------+-------------+ | hour(order_date) | sum(amount) | +------------------+-------------+ | 8 | 600 | | 9 | 575 | | 10 | 505 | | 11 | 600 | +------------------+-------------+
En la consulta anterior, simplemente agrupamos por order_date usando la función HORA y agregando cantidad columna usando la función SUMA.
La función HORA recupera el número de hora de un valor de fecha/hora/fechahora determinado, que se puede proporcionar como una cadena literal o un nombre de columna.
Si desea mostrar los valores de hora usando la notación AM/PM, como 8 AM, 9 AM, etc., debe usar la función date_format que le permite cambiar el formato de un valor de fecha/hora/fechahora dado, que se puede proporcionar como un cadena literal o nombre de columna.
mysql> select date_format(order_date,'%H %p') as hour, sum(amount) as total_sales from sales group by date_format(order_date,'%H %p'); +-------+-------------+ | hour | total_sales | +-------+-------------+ | 08 AM | 600 | | 09 AM | 575 | | 10 AM | 505 | | 11 AM | 600 | +-------+-------------+
¿Necesita una herramienta de informes para MySQL? Ubiq facilita la visualización de datos en minutos y la supervisión en paneles en tiempo real. ¡Pruébalo hoy!