PostgreSQL
 sql >> Base de Dados >  >> RDS >> PostgreSQL

Como selecionar registros das últimas 24 horas usando o PostgreSQL


Às vezes, pode ser necessário obter registros das últimas 24 horas ou selecionar linhas das últimas 24 horas para relatórios e análises. Aqui está como selecionar registros das últimas 24 horas usando o PostgreSQL.



Obter registros das últimas 24 horas no PostgreSQL


Aqui está a consulta SQL para obter registros das últimas 24 horas no PostgreSQL. Digamos que você tenha a seguinte tabela vendas(data_pedido, quantidade) .
postgres-# create table sales(order_date timestamp, amount int);

postgres-# insert into sales(order_date,amount) 
     values('2020-06-07 01:00:00',200),
     ('2020-06-07 02:30:00',350),
     ('2020-06-07 04:40:00',410),
     ('2020-06-07 12:10:00',600),
     ('2020-06-07 15:00:00',300),
     ('2020-06-07 18:55:00',450),
     ('2020-06-07 21:00:00',1200),
     ('2020-06-08 03:00:00',800),
     ('2020-06-08 05:30:00',900),
     ('2020-06-08 07:20:00',100),
     ('2020-06-08 10:10:00',250),
     ('2020-06-08 12:05:00',300),
     ('2020-06-08 13:30:00',200);

postgres-# select * from sales;
+---------------------+--------+
| order_date          | amount |
+---------------------+--------+
| 2020-06-07 01:00:00 |    200 |
| 2020-06-07 02:30:00 |    350 |
| 2020-06-07 04:40:00 |    410 |
| 2020-06-07 12:10:00 |    600 |
| 2020-06-07 15:00:00 |    300 |
| 2020-06-07 18:55:00 |    450 |
| 2020-06-07 21:00:00 |   1200 |
| 2020-06-08 03:00:00 |    800 |
| 2020-06-08 05:30:00 |    900 |
| 2020-06-08 07:20:00 |    100 |
| 2020-06-08 10:10:00 |    250 |
| 2020-06-08 12:05:00 |    300 |
| 2020-06-08 13:30:00 |    200 |
+---------------------+--------+

Bônus de leitura:Como aumentar o máximo de conexões no PostgreSQL



Obter linhas das últimas 24 horas no PostgreSQL


Aqui está a consulta SQL para obter registros das últimas 24 horas no PostgreSQL.
postgres-# select * from sales
       where order_date > now() - interval '24 hours';
+---------------------+--------+
| order_date          | amount |
+---------------------+--------+
| 2020-06-07 15:00:00 |    300 |
| 2020-06-07 18:55:00 |    450 |
| 2020-06-07 21:00:00 |   1200 |
| 2020-06-08 03:00:00 |    800 |
| 2020-06-08 05:30:00 |    900 |
| 2020-06-08 07:20:00 |    100 |
| 2020-06-08 10:10:00 |    250 |
| 2020-06-08 12:05:00 |    300 |
| 2020-06-08 13:30:00 |    200 |
+---------------------+--------+

Na consulta SQL acima, usamos a função do sistema PostgreSQL now() para obter a data e hora atual. Em seguida, usamos a cláusula INTERVAL para selecionar as linhas em que order_date cai dentro das últimas 24 horas da data e hora atual.

Leitura bônus:Dicas de ajuste de desempenho do PostgreSQL

Você também pode especificar o intervalo de tempo em dias, em vez de horas.
postgres-# select * from sales
     where order_date > now() - interval '1 day';
+---------------------+--------+
| order_date          | amount |
+---------------------+--------+
| 2020-06-07 15:00:00 |    300 |
| 2020-06-07 18:55:00 |    450 |
| 2020-06-07 21:00:00 |   1200 |
| 2020-06-08 03:00:00 |    800 |
| 2020-06-08 05:30:00 |    900 |
| 2020-06-08 07:20:00 |    100 |
| 2020-06-08 10:10:00 |    250 |
| 2020-06-08 12:05:00 |    300 |
| 2020-06-08 13:30:00 |    200 |
+---------------------+--------+

Bônus de leitura:As 5 principais ferramentas de monitoramento de consultas PostgreSQL

Se você deseja selecionar registros apenas para o dia atual e não para as últimas 24 horas, use a consulta a seguir.
postgres-# select * from sales
      where date_trunc('date',order_date) = current_date;
+---------------------+--------+
| order_date          | amount |
+---------------------+--------+
| 2020-06-08 03:00:00 |    800 |
| 2020-06-08 05:30:00 |    900 |
| 2020-06-08 07:20:00 |    100 |
| 2020-06-08 10:10:00 |    250 |
| 2020-06-08 12:05:00 |    300 |
| 2020-06-08 13:30:00 |    200 |
+---------------------+--------+

Na consulta acima, você obterá apenas a data atual das linhas e não as últimas 24 horas. Usamos a função DATE_TRUNCT para selecionar apenas as linhas em que o valor de data de order_date é igual ao valor de data da variável de sistema CURRENT_DATE, ou seja, a data atual.

A Ubiq facilita a visualização de dados em minutos e o monitoramento em painéis em tempo real. Experimente hoje!