PostgreSQL: получить предпоследний MAX (дата)

У меня есть два представления в PostgreSQL. Один, чтобы получить самые последние общие суммы каждой организации. Другая точка зрения состоит в том, чтобы получить предпоследнюю общую сумму каждой организации, и вот проблема: как получить предпоследнюю MAX (дату) в PostgreSQL? Это мой код (обратите внимание, что «дата» — это один из моих столбцов, а не функция):

CREATE VIEW vw_totaaldossiers AS
SELECT SUM(aantal) as totaal
FROM _dossier i1
WHERE date = (
    SELECT MAX(date) 
    FROM _dossier i2 
    WHERE i2.instantie = i1.instantie 
    GROUP BY i2.instantie
);

CREATE VIEW v2_relatiefdossiers AS
SELECT SUM(aantal) as relatief
FROM _dossier i3
WHERE date = (
    SELECT /* Here comes the second to last MAX(date) */ 
    FROM _dossier i4
    WHERE i4.instantie = i3.instantie
    GROUP BY i4.instantie
);

Спасибо за помощь!


person user2213250    schedule 15.05.2013    source источник


Ответы (2)


Что-то вроде этого:

SELECT SUM(aantal) as relatief
FROM _dossier i3
WHERE date = (
    SELECT date 
    from (
       select date, 
              dense_rank() over (partition by i4.instantie order by date desc) as rnk
       FROM _dossier i4
       WHERE i4.instantie = i3.instantie
    ) t 
    where rnk = 2;
);

Я не совсем уверен, что i3 действительно виден внутри вложенной производной таблицы!

Вам нужно будет запустить explain, чтобы узнать, быстрее или медленнее выполняется запрос LIMI/OFFSET от Виктора.

person a_horse_with_no_name    schedule 15.05.2013

person    schedule
comment
Убедитесь, что у _dossier.date есть индекс. - person Andrew Lazarus; 15.05.2013
comment
Большое спасибо. Это работает. Искали в интернете часа 3. ;) - person user2213250; 15.05.2013