2013-05-15 32 views
1

我在PostgreSQL中有兩個視圖。一個獲取每個組織的最新總金額。另一種觀點是獲得每個組織的第二個到最後一個總量,這裏是問題:如何在PostgreSQL中獲得第二個MAX(date)?這是我的代碼(注意「日期」是我的專欄之一,而不是函數):PostgreSQL:獲取第二個最後的MAX(日期)

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 
); 

感謝您的幫助!

回答

1

事情是這樣的:

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以查明Wiktor的LIMI/OFFSET查詢是更快還是更慢。

5
SELECT date 
FROM _dossier i2 
WHERE i2.instantie = i1.instantie 
GROUP BY i2.instantie 
ORDER BY date DESC LIMIT 1 OFFSET 1 
+0

確保_dossier.date有一個索引。 –

+0

非常感謝。這工作。一直在像3小時在互聯網上搜索。 ;) – user2213250

相關問題