Rumah >pangkalan data >tutorial mysql >Bagaimana Menggunakan Fungsi Tetingkap PostgreSQL dengan Betul dengan Klausa GROUP BY?
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.
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.
Untuk menangani isu tersebut, pengguna boleh sama ada:
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.
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!