Rumah >pangkalan data >tutorial mysql >Bagaimana untuk Membetulkan Ralat 'Penggunaan Fungsi Kumpulan Tidak Sah' MySQL dalam Subkueri?

Bagaimana untuk Membetulkan Ralat 'Penggunaan Fungsi Kumpulan Tidak Sah' MySQL dalam Subkueri?

Barbara Streisand
Barbara Streisandasal
2025-01-11 22:38:46858semak imbas

How to Fix MySQL's

Menyahpepijat Ralat "Penggunaan Fungsi Kumpulan Tidak Sah" MySQL

Masalah:

Pertanyaan yang direka untuk mengenal pasti bahagian yang dibekalkan oleh sekurang-kurangnya dua pembekal mengakibatkan ralat "Penggunaan fungsi kumpulan tidak sah":

<code class="language-sql">SELECT c1.pid                      -- Select part ID (pid)
FROM Catalog AS c1                 -- From the Catalog table
WHERE c1.pid IN (                  -- Where pid is in the set:
    SELECT c2.pid                  -- Of pids
    FROM Catalog AS c2             -- From the Catalog table
    WHERE c2.pid = c1.pid AND COUNT(c2.sid) >= 2 -- Incorrect: COUNT in WHERE clause
);</code>

Isunya:

Ralat berpunca daripada peletakan fungsi COUNT() yang tidak betul. Klausa WHERE menapis baris individu sebelum pengumpulan, menjadikan fungsi agregat COUNT() tidak sah dalam konteks ini.

Penyelesaian:

Pendekatan yang betul melibatkan penggunaan klausa HAVING, yang menapis selepas pengumpulan dan pengagregatan:

<code class="language-sql">SELECT c1.pid
FROM Catalog AS c1
WHERE c1.pid IN (
    SELECT c2.pid
    FROM Catalog AS c2
    GROUP BY c2.pid
    HAVING COUNT(c2.sid) >= 2
);</code>

Penjelasan:

Pertanyaan yang disemak mengumpulkan jadual Catalog dengan pid menggunakan GROUP BY c2.pid. Klausa HAVING kemudian menapis kumpulan ini, mengekalkan hanya kumpulan yang bilangan ID pembekal (sid) lebih besar daripada atau sama dengan dua. Ini dengan betul mengenal pasti bahagian dengan sekurang-kurangnya dua pembekal. Pertanyaan luar kemudian memilih nilai pid daripada kumpulan yang ditapis ini.

Atas ialah kandungan terperinci Bagaimana untuk Membetulkan Ralat 'Penggunaan Fungsi Kumpulan Tidak Sah' MySQL dalam Subkueri?. 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