Rumah >pangkalan data >tutorial mysql >Mengapa 'Lajur Mesti Muncul dalam GROUP BY Klausa atau Digunakan dalam Fungsi Agregat' Berlaku dalam Pertanyaan SQL?

Mengapa 'Lajur Mesti Muncul dalam GROUP BY Klausa atau Digunakan dalam Fungsi Agregat' Berlaku dalam Pertanyaan SQL?

Patricia Arquette
Patricia Arquetteasal
2025-01-18 14:01:09511semak imbas

Why Does

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!

Kenyataan:
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