Ralat SQL: Lajur mesti muncul dalam klausa GROUP BY atau digunakan sebagai fungsi agregat
Apabila melaksanakan pertanyaan pengagregatan berkumpulan, anda mesti memastikan bahawa lajur yang dipilih sama ada muncul dalam klausa GROUP BY
atau mengambil bahagian dalam pengiraan fungsi agregat. Jika tidak, mesej ralat yang serupa dengan "Lajur mesti muncul dalam klausa GROUP BY atau digunakan sebagai fungsi agregat" akan muncul.
Huraian Masalah
Andaikan terdapat jadual bernama makerar
dengan lajur cname
, wmname
dan avg
. Matlamatnya adalah untuk mendapatkan nilai cname
maksimum untuk setiap avg
yang berbeza. Walau bagaimanapun, laksanakan pertanyaan berikut:
<code class="language-sql">SELECT cname, wmname, MAX(avg) FROM makerar GROUP BY cname;</code>
akan membuang ralat kerana lajur wmname
tidak disertakan dalam klausa GROUP BY
mahupun digunakan sebagai fungsi agregat.
Penyelesaian
Terdapat dua cara utama untuk menyelesaikan masalah ini:
1. Kaedah subquery dan join
Kaedah ini menggunakan subkueri untuk mengira nilai cname
maksimum bagi setiap avg
dan kemudian bergabung dengan subkueri dengan jadual utama untuk mendapatkan wmname
yang sepadan:
<code class="language-sql">SELECT m.cname, m.wmname, t.mx FROM ( SELECT cname, MAX(avg) AS mx FROM makerar GROUP BY cname ) t JOIN makerar m ON m.cname = t.cname AND t.mx = m.avg ;</code>
2. Kaedah fungsi tetingkap
Fungsi tetingkap menyediakan alternatif yang lebih mudah untuk melakukan pengiraan agregat dalam kumpulan:
<code class="language-sql">SELECT cname, wmname, MAX(avg) OVER (PARTITION BY cname) AS mx FROM makerar ;</code>
Nota: Walaupun fungsi tetingkap dengan betul memaparkan nilai cname
maksimum untuk setiap avg
, ia mungkin menghasilkan rekod pendua.
Atas ialah kandungan terperinci Mengapa 'Lajur Mesti Muncul dalam GROUP BY Klausa atau Digunakan dalam Fungsi Agregat' Berlaku dalam Pertanyaan SQL?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!