Rumah > pangkalan data > tutorial mysql > Bagaimana Mengira Baris Sebelumnya Dalam Julat Masa dalam PostgreSQL?

Bagaimana Mengira Baris Sebelumnya Dalam Julat Masa dalam PostgreSQL?

Susan Sarandon
Lepaskan: 2024-12-19 16:14:13
asal
598 orang telah melayarinya

How to Count Previous Rows Within a Time Range in PostgreSQL?

Kira Baris Sebelumnya dalam Julat Masa

Dalam PostgreSQL, anda boleh menentukan jumlah bilangan rekod sebelumnya dalam julat masa tertentu untuk setiap baris menggunakan fungsi tetingkap.

Menggunakan RANGE dalam fungsi tetingkap (Postgres 11 atau lebih baharu)

Untuk Postgres 11 atau lebih baru, mod RANGE membolehkan anda menentukan julat masa menggunakan pilihan SEBELUM DAN KECUALI:

SELECT id, ts
, count(*) OVER (ORDER BY ts RANGE '1 hour' PRECEDING EXCLUDE CURRENT ROW)
FROM test
ORDER BY ts;
Salin selepas log masuk

Versi PostgreSQL Lama

Untuk versi PostgreSQL yang lebih awal, pendekatan lain ialah disyorkan:

Pertanyaan Rom (ROM)

SELECT id, ts
, (SELECT count(*)::int - 1
FROM unnest(dates) x
WHERE x >= sub.ts - interval '1h') AS ct
FROM (
SELECT id, ts
, array_agg(ts) OVER (ORDER BY ts) AS dates
FROM test
) sub;
Salin selepas log masuk

Pengiraan Tatasusunan (ARR)

SELECT id, ts
, (SELECT count(*)
FROM test t1
WHERE t1.ts >= t.ts - interval '1h'
AND t1.ts < t.ts) AS ct
FROM test t
ORDER BY ts;
Salin selepas log masuk

Fungsi PL/pgSQL (FNC)

CREATE OR REPLACE FUNCTION running_window_ct(_intv interval = '1 hour')
RETURNS TABLE (id bigint, ts timestamp, ct int) AS
$func$
DECLARE
cur CURSOR FOR
SELECT t.ts + _intv AS ts1
, row_number() OVER (ORDER BY t.ts ROWS UNBOUNDED PRECEDING) AS rn
FROM test t
ORDER BY t.ts;
rec record;
rn int;
BEGIN
OPEN cur;
FETCH cur INTO rec;
ct := -1;

FOR id, ts, rn IN
SELECT t.id, t.ts, row_number() OVER (ORDER BY t.ts ROWS UNBOUNDED PRECEDING)
FROM test t ORDER BY t.ts
LOOP
IF rec.ts1 >= ts THEN
ct := ct + 1;
ELSE
LOOP
FETCH cur INTO rec;
EXIT WHEN rec.ts1 >= ts;
END LOOP;
ct := rn - rec.rn;
END IF;

RETURN NEXT;
END LOOP;
END
$func$;
Salin selepas log masuk

Panggil fungsi dengan selang masa yang dikehendaki:

SELECT * FROM running_window_ct('1 hour');
Salin selepas log masuk

Atas ialah kandungan terperinci Bagaimana Mengira Baris Sebelumnya Dalam Julat Masa dalam PostgreSQL?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan