Às vezes, você pode precisar buscar as linhas da semana passada no MySQL para relatórios e análises. Veja como obter dados da semana passada no MySQL.
Como obter dados da última semana no MySQL
Aqui estão as etapas para obter dados da semana passada no MySQL. Digamos que você tenha a seguinte tabela 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 | +------+------------+--------+
Bônus de leitura:MySQL Copy Database
Aqui está a consulta SQL para obter os dados da semana passada no 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 | +------+------------+--------+
Na consulta SQL acima, usamos a função WEEK() para obter o número da semana de order_date coluna. Selecionamos apenas os registros cujo número da semana é 1 a menos que o número da semana da data de hoje, obtido pela função NOW().
Bônus de leitura:MySQL Inserir em Select
Como obter dados dos últimos 7 dias no MySQL
Às vezes, pode ser necessário buscar registros dos últimos 7 dias. Aqui está a consulta SQL para obter os dados dos últimos 7 dias no 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 | +------+------------+--------+
Na consulta acima, selecionamos os registros cujo order_date é após um intervalo passado de 7 dias a partir de hoje.
Bônus de leitura:MySQL Select Top N Rows
O Ubiq facilita a visualização de dados em minutos e o monitoramento em painéis em tempo real. Experimente hoje!