sql >> Base de Datos >  >> RDS >> PostgreSQL

Cómo seleccionar registros de las últimas 24 horas usando PostgreSQL

A veces, es posible que necesite obtener registros de las últimas 24 horas o seleccionar filas de las últimas 24 horas para informes y análisis. Aquí se explica cómo seleccionar registros de las últimas 24 horas usando PostgreSQL.


Obtener registros de las últimas 24 horas en PostgreSQL

Aquí está la consulta SQL para obtener registros de las últimas 24 horas en PostgreSQL. Supongamos que tiene la siguiente tabla ventas (fecha_pedido, cantidad) .

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

Lectura adicional:Cómo aumentar el número máximo de conexiones en PostgreSQL


Obtener filas de las últimas 24 horas en PostgreSQL

Aquí está la consulta SQL para obtener registros de las últimas 24 horas en 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 |
+---------------------+--------+

En la consulta SQL anterior, usamos la función del sistema PostgreSQL ahora() para obtener la fecha y hora actual. Luego usamos la cláusula INTERVAL para seleccionar aquellas filas donde order_date cae dentro de las últimas 24 horas de la fecha y hora actual.

Lectura adicional:Sugerencias para ajustar el rendimiento de PostgreSQL

También puede especificar el intervalo de tiempo en días, en lugar 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 |
+---------------------+--------+

Lectura adicional:Las 5 mejores herramientas de supervisión de consultas de PostgreSQL

Si desea seleccionar registros solo para el día actual, y no más allá de las 24 horas, utilice la siguiente consulta.

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

En la consulta anterior, obtendrá filas solo en la fecha actual y no en las últimas 24 horas. Usamos la función DATE_TRUNCT para seleccionar solo aquellas filas donde el valor de fecha de order_date es el mismo que el valor de fecha de la variable de sistema CURRENT_DATE, es decir, la fecha actual.

Ubiq facilita la visualización de datos en minutos y el monitoreo en paneles en tiempo real. ¡Pruébalo hoy!