


Bagaimana Menggunakan Fungsi Tetingkap PostgreSQL dengan Betul dengan Klausa GROUP BY?
Jan 06, 2025 am 11:33 AMFungsi Tetingkap PostgreSQL dan Kumpulan Mengikut Pengecualian
Apabila cuba menggunakan fungsi tetingkap bersama dengan klausa GROUP BY dalam PostgreSQL, adalah penting untuk memahami perbezaan antara dua. Fungsi tetingkap beroperasi pada partition data jadual, melakukan pengiraan merentas baris sambil mengekalkan semua baris, tidak seperti fungsi agregat yang meringkaskan baris menjadi satu nilai. Oleh itu, apabila menggunakan fungsi tetingkap, adalah penting untuk memasukkan lajur yang dipartisi dalam klausa KUMPULAN OLEH.
Penerangan Isu
Dalam pertanyaan yang diberikan, pengguna menghadapi ralat semasa cuba melaksanakan perkara berikut kod:
SELECT p.name, e.date, sum(sp.payout) OVER (ORDER BY e.date) - sum(s.buyin) OVER (ORDER BY e.date) AS "Profit/Loss" FROM result r JOIN game g ON r.game_id = g.game_id JOIN event e ON g.event_id = e.event_id JOIN structure s ON g.structure_id = s.structure_id JOIN structure_payout sp ON g.structure_id = sp.structure_id AND r.position = sp.position JOIN player p ON r.player_id = p.player_id WHERE p.player_id = 17 GROUP BY p.name, e.date, e.event_id, sp.payout, s.buyin ORDER BY p.name, e.date ASC
Ralat timbul kerana tetingkap berfungsi, sum(sp.payout) OVER (PESANAN MENGIKUT e.tarikh) dan jumlah(s.buyin) LEBIH (PESANAN MENGIKUT e.tarikh), tidak disertakan dengan fungsi agregat. Akibatnya, PostgreSQL menuntut lajur yang dipartisi, sp.payout dan s.buyin, dimasukkan ke dalam klausa GROUP BY.
Penyelesaian
Untuk menangani isu tersebut, pengguna boleh sama ada:
- Sertakan sp.payout dan s.buyin dalam KUMPULAN MENGIKUT klausa:
GROUP BY p.name, e.date, e.event_id
Walau bagaimanapun, pendekatan ini boleh membawa kepada berbilang baris untuk setiap pemain dan acara jika terdapat berbilang nilai sp.payout atau s.buyin.
- Gunakan gabungan fungsi tetingkap dan agregat fungsi:
SELECT p.name , e.event_id , e.date , sum(sum(sp.payout)) OVER w - sum(sum(s.buyin )) OVER w AS "Profit/Loss" FROM player p JOIN result r ON r.player_id = p.player_id JOIN game g ON g.game_id = r.game_id JOIN event e ON e.event_id = g.event_id JOIN structure s ON s.structure_id = g.structure_id JOIN structure_payout sp ON sp.structure_id = g.structure_id AND sp.position = r.position WHERE p.player_id = 17 GROUP BY e.event_id WINDOW w AS (ORDER BY e.date, e.event_id) ORDER BY e.date, e.event_id;
Dalam contoh ini, jumlah(jumlah(sp.payout)) LEBIH w dan jumlah(jumlah(s.buyin)) OVER w ekspresi menggabungkan tetingkap luar berfungsi dengan fungsi agregat dalaman untuk mengira jumlah pembayaran dan pembelian bagi setiap acara.
Atas ialah kandungan terperinci Bagaimana Menggunakan Fungsi Tetingkap PostgreSQL dengan Betul dengan Klausa GROUP BY?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Artikel Panas

Alat panas Tag

Artikel Panas

Tag artikel panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas

Kurangkan penggunaan memori MySQL di Docker

Bagaimana anda mengubah jadual di MySQL menggunakan pernyataan Alter Table?

Cara menyelesaikan masalah MySQL tidak dapat membuka perpustakaan bersama

Apa itu SQLite? Gambaran Keseluruhan Komprehensif

Jalankan MySQL di Linux (dengan/tanpa bekas podman dengan phpmyadmin)

Menjalankan Pelbagai Versi MySQL di MacOS: Panduan Langkah demi Langkah

Bagaimanakah saya menjamin MySQL terhadap kelemahan biasa (suntikan SQL, serangan kekerasan)?

Bagaimana saya mengkonfigurasi penyulitan SSL/TLS untuk sambungan MySQL?
