PostgreSQL
 sql >> Datenbank >  >> RDS >> PostgreSQL

Wie nehme ich eine DISTINCT ON-Unterabfrage, die nach einer separaten Spalte geordnet ist, und mache sie schnell?

Ich frage mich, ob Sie das zum Laufen bringen können:

select article_id, id, article_published_date
from prediction p
where p.prediction_date = (select max(p2.prediction_date)
                           from prediction p2
                           where p2.article_id = p.article_id
                          )
order by article_published_date desc;

Verwenden Sie dann diese beiden Indizes:

  • (article_published_date desc, prediction_date, article_id, id)
  • (article_id, prediction_date desc) .