sql >> Databasteknik >  >> RDS >> Mysql

Hur man får data för varje timme i MySQL

Ibland kan du behöva hämta timdata eller hämta poster för varje timme i MySQL. I den här artikeln kommer vi att titta på hur man får data för varje timme i MySQL.


Hur man får data för varje timme i MySQL

Här är stegen för att få data för varje timme i MySQL. Låt oss säga att du har följande tabell försäljning(id, order_date, summa)

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


Hur man får data för varje timme i MySQL

Här är SQL-frågan för att få data för varje timme i 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 |
 +------------------+-------------+

I ovanstående fråga grupperar vi helt enkelt efter order_date använder HOUR-funktionen och sammanställt belopp kolumn med SUM-funktionen.

HOUR-funktionen hämtar timtal från ett givet datum/tid/datetime-värde, vilket kan anges som en bokstavlig sträng eller kolumnnamn.

Om du vill visa timvärden med AM/PM-notation såsom 8AM, 9AM , etc, måste du använda date_format-funktionen som låter dig ändra formatet för ett givet datum/tid/datetime-värde, vilket kan tillhandahållas som en bokstavlig sträng eller kolumnnamn.

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

Behöver du ett rapporteringsverktyg för MySQL? Ubiq gör det enkelt att visualisera data på några minuter och övervaka i realtidsinstrumentpaneler. Prova det idag!

  1. DNA vs moderna säkerhetskopieringsmetoder:Framtiden för datalagring

  2. Hur man hanterar en tabellkolumn med ett reserverat SQL-sökord?

  3. Förbyggd Oracle-databas för inlärning och testning med Oracle Developer VM

  4. ORA-21700:objektet finns inte eller är markerat för borttagning för Associative Array som indataparameter anropad från ODP.NET