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

Comment obtenir des données pour chaque heure dans MySQL

Parfois, vous devrez peut-être obtenir des données horaires ou récupérer des enregistrements pour chaque heure dans MySQL. Dans cet article, nous verrons comment obtenir des données pour chaque heure dans MySQL.


Comment obtenir des données pour chaque heure dans MySQL

Voici les étapes pour obtenir des données pour chaque heure dans MySQL. Disons que vous avez le tableau suivant ventes(id, date_commande, montant)

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 |
 +------+---------------------+--------+


Comment obtenir des données pour chaque heure dans MySQL

Voici la requête SQL pour obtenir des données pour chaque heure dans 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 |
 +------------------+-------------+

Dans la requête ci-dessus, nous regroupons simplement par order_date en utilisant la fonction HOUR et le montant agrégé colonne à l'aide de la fonction SOMME.

La fonction HOUR récupère le numéro d'heure à partir d'une valeur date/heure/dateheure donnée, qui peut être fournie sous forme de chaîne littérale ou de nom de colonne.

Si vous souhaitez afficher les valeurs d'heure en utilisant la notation AM/PM telle que 8AM, 9AM , etc., vous devez utiliser la fonction date_format qui vous permet de modifier le format d'une valeur date/heure/datetime donnée, qui peut être fournie en tant que chaîne littérale ou nom de colonne.

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 |
 +-------+-------------+

Besoin d'un outil de reporting pour MySQL ? Ubiq facilite la visualisation des données en quelques minutes et la surveillance dans des tableaux de bord en temps réel. Essayez-le aujourd'hui !