Rumah >pangkalan data >tutorial mysql >Bagaimana untuk Membetulkan Ralat 'Penggunaan Fungsi Kumpulan Tidak Sah' MySQL dalam Subkueri?
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!