"Si un trabajador quiere hacer bien su trabajo, primero debe afilar sus herramientas." - Confucio, "Las Analectas de Confucio. Lu Linggong"
Página delantera > Programación > ¿Cómo recuperar eficientemente la última fila para cada identificador único en PostgreSQL?

¿Cómo recuperar eficientemente la última fila para cada identificador único en PostgreSQL?

Publicado el 2025-04-04
Navegar:652

How to Efficiently Retrieve the Last Row for Each Unique Identifier in PostgreSQL?

postgresql: extrayendo la última fila para cada identificador único

en postgresql, puede encontrar situaciones en las que necesita extraer la información de la última fila asociada con cada identificador distinto dentro de un conjunto de datos. Considere los siguientes datos:

select distinct on (id) id, date, another_info
from the_table
order by id, date desc;


para recuperar la última fila de información para cada identificación única en el conjunto de datos, puede emplear el operador eficiente de Postgres en el operador:
distintivo en (id) ID, fecha, otra_info de The_Table Orden por id, date Desc;

Esta consulta devolverá la siguiente salida:
select id, date, another_info
from (
  select id, date, another_info, 
         row_number() over (partition by id order by date desc) as rn
  from the_table
) t
where rn = 1
order by id;
 id fecha otra_info 

1 2014-05-13 kgfd

2 2014-02-01 sada

Una solución entre database que puede sacrificar un ligero rendimiento, puede usar una función de ventana:

Seleccionar id, fecha, otro_info de ( Seleccione ID, fecha, otro_info, row_number () Over (Partition por orden de identificación por fecha Desc) como RN de The_Table ) t donde rn = 1 orden por id;

En la mayoría de los casos, la solución que involucra una función de ventana es más rápida que usar un sub-QUERTO.

Último tutorial Más>

Descargo de responsabilidad: Todos los recursos proporcionados provienen en parte de Internet. Si existe alguna infracción de sus derechos de autor u otros derechos e intereses, explique los motivos detallados y proporcione pruebas de los derechos de autor o derechos e intereses y luego envíelos al correo electrónico: [email protected]. Lo manejaremos por usted lo antes posible.

Copyright© 2022 湘ICP备2022001581号-3