Rumah > pangkalan data > tutorial mysql > Bagaimana untuk Mendapatkan Kiraan Baris Berjalan mengikut Minit dalam PostgreSQL?

Bagaimana untuk Mendapatkan Kiraan Baris Berjalan mengikut Minit dalam PostgreSQL?

Mary-Kate Olsen
Lepaskan: 2025-01-19 00:42:09
asal
743 orang telah melayarinya

How to Get a Running Row Count by Minute in PostgreSQL?

PostgreSQL: Mengira Kiraan Baris Berjalan mengikut Minit

Artikel ini menunjukkan cara mendapatkan kiraan baris berjalan untuk pertanyaan, dikumpulkan mengikut minit dalam PostgreSQL. Cabarannya ialah untuk mengira baris dengan tepat untuk setiap minit, walaupun yang tiada aktiviti.

Memanfaatkan Fungsi Tetingkap

Penyelesaian paling cekap menggunakan fungsi tetingkap berkuasa PostgreSQL. Fungsi ini beroperasi pada set baris, membolehkan pengiraan merentas berbilang baris. Di sini, kami menggunakan fungsi COUNT dalam tetingkap yang dibahagikan mengikut minit.

Pertanyaan Cekap menggunakan SELECT DISTINCT dan ORDER BY

Pertanyaan ini menggunakan SELECT DISTINCT untuk memastikan entri minit yang unik dan COUNT dengan fungsi tetingkap untuk menjana kiraan larian. ORDER BY menjamin jumlah terkumpul yang betul untuk setiap selang minit.

<code class="language-sql">SELECT DISTINCT
       date_trunc('minute', "when") AS minute,
       count(*) OVER (ORDER BY date_trunc('minute', "when")) AS running_ct
FROM   mytable
ORDER  BY 1;</code>
Salin selepas log masuk

Memahami Sintaks Fungsi Tetingkap

Jom pecahkan fungsi tingkap:

  • COUNT(*): Mengira baris dalam setiap partition minit.
  • OVER (ORDER BY date_trunc('minute', "when")): Mentakrifkan tetingkap sebagai jujukan baris, disusun mengikut minit, mengumpul kiraan dari awal.

Mengendalikan Minit dengan Sifar Aktiviti

Untuk memasukkan minit tanpa aktiviti (baris sifar), kami menggunakan generate_series untuk mencipta satu siri minit dan kemudian melakukan LEFT JOIN untuk memasukkan minit tersebut walaupun mereka kekurangan entri yang sepadan dalam jadual:

<code class="language-sql">SELECT DISTINCT
       minute, count(c.minute) OVER (ORDER BY minute) AS running_ct
FROM  (
   SELECT generate_series(date_trunc('minute', min("when")), max("when"), interval '1 min')
   FROM   mytable
   ) m(minute)
LEFT   JOIN (SELECT date_trunc('minute', "when") AS minute FROM mytable) c USING (minute)
ORDER  BY 1;</code>
Salin selepas log masuk

Pertimbangan Prestasi

Walaupun fungsi tetingkap biasanya optimum untuk set data yang besar, untuk set data yang lebih kecil, alternatif menggunakan SUM() mungkin menawarkan prestasi yang lebih baik. Pendekatan ini mula-mula mengumpulkan dan mengira baris seminit, kemudian menggunakan SUM() untuk mengira jumlah larian:

<code class="language-sql">SELECT minute, sum(minute_ct) OVER (ORDER BY minute) AS running_ct
FROM  (
   SELECT date_trunc('minute', "when") AS minute,
        count(*) AS minute_ct
   FROM   tbl
   GROUP  BY 1
   ) sub
ORDER  BY 1;</code>
Salin selepas log masuk

Pendekatan terbaik bergantung pada saiz set data dan keperluan prestasi anda. Menguji kedua-dua kaedah disyorkan untuk menentukan penyelesaian yang paling berkesan untuk kes penggunaan khusus anda.

Atas ialah kandungan terperinci Bagaimana untuk Mendapatkan Kiraan Baris Berjalan mengikut Minit 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