Ibland kan du behöva hämta förra veckans rader i MySQL för rapportering och analys. Så här får du förra veckans data i MySQL.
Hur får du förra veckans data i MySQL
Här är stegen för att få förra veckans data i MySQL. Anta att du har följande tabell product_orders(id, order_date, amount)
mysql> create table product_orders(id int, order_date date, amount int);
mysql> insert into product_orders values(1,'2020-07-20',100),
(2,'2020-07-21',250),
(3,'2020-07-22',225),
(4,'2020-07-23',150),
(5,'2020-07-24',200),
(6,'2020-07-25',180),
(7,'2020-07-26',150),
(8,'2020-07-27',200),
(9,'2020-07-28',250),
(10,'2020-07-29',300),
(11,'2020-07-30',150),
(12,'2020-07-31',200),
(13,'2020-08-01',180),
(14,'2020-08-02',200);
mysql> select * from product_orders;
+------+------------+--------+
| id | order_date | amount |
+------+------------+--------+
| 1 | 2020-07-20 | 100 |
| 2 | 2020-07-21 | 250 |
| 3 | 2020-07-22 | 225 |
| 4 | 2020-07-23 | 150 |
| 5 | 2020-07-24 | 200 |
| 6 | 2020-07-25 | 180 |
| 7 | 2020-07-26 | 150 |
| 8 | 2020-07-27 | 200 |
| 9 | 2020-07-28 | 250 |
| 10 | 2020-07-29 | 300 |
| 11 | 2020-07-30 | 150 |
| 12 | 2020-07-31 | 200 |
| 13 | 2020-08-01 | 180 |
| 14 | 2020-08-02 | 200 |
+------+------------+--------+
Bonus Läs:MySQL Copy Database
Här är SQL-frågan för att hämta förra veckans data i MySQL.
mysql> select * from product_orders where week(order_date)=week(now())-1; +------+------------+--------+ | id | order_date | amount | +------+------------+--------+ | 7 | 2020-07-26 | 150 | | 8 | 2020-07-27 | 200 | | 9 | 2020-07-28 | 250 | | 10 | 2020-07-29 | 300 | | 11 | 2020-07-30 | 150 | | 12 | 2020-07-31 | 200 | | 13 | 2020-08-01 | 180 | +------+------------+--------+
I SQL-frågan ovan använder vi funktionen WEEK() för att få veckonummer order_date kolumn. Vi väljer bara de poster vars veckonummer är 1 mindre än veckonumret för dagens datum, erhållet med hjälp av NOW()-funktionen.
Bonus Läs:MySQL Infoga i Select
Hur får du data från de senaste 7 dagarna i MySQL
Ibland kan du behöva hämta uppgifter från de senaste 7 dagarna. Här är SQL-frågan för att hämta data från de senaste 7 dagarna i MySQL.
mysql> select * from product_orders where order_date> now() - interval 7 day; +------+------------+--------+ | id | order_date | amount | +------+------------+--------+ | 9 | 2020-07-28 | 250 | | 10 | 2020-07-29 | 300 | | 11 | 2020-07-30 | 150 | | 12 | 2020-07-31 | 200 | | 13 | 2020-08-01 | 180 | | 14 | 2020-08-02 | 200 | +------+------------+--------+
I frågan ovan väljer vi de poster vars orderdatum är efter ett tidigare intervall på 7 dagar från idag.
Bonus Läs:MySQL Välj Top N Rows
Ubiq gör det enkelt att visualisera data på några minuter och övervaka i realtidsinstrumentpaneler. Prova det idag!