Heim > Datenbank > MySQL-Tutorial > Wie behebe ich den Fehler „Operand sollte 1 Spalte enthalten' in der NOT IN-Unterabfrage von MySQL?

Wie behebe ich den Fehler „Operand sollte 1 Spalte enthalten' in der NOT IN-Unterabfrage von MySQL?

Barbara Streisand
Freigeben: 2025-01-12 07:13:46
Original
436 Leute haben es durchsucht

How to Fix the

MySQL-Fehler „Operand sollte 1 Spalte enthalten“ in NOT IN-Unterabfragen: Eine Lösung

MySQLs NOT IN-Klausel erfordert, dass die Unterabfrage eine einzelne Spalte zurückgibt. Die folgende Abfrage generiert den Fehler „Operand sollte 1 Spalte enthalten“, da die Unterabfrage mehrere Spalten zurückgibt:

<code class="language-sql">SELECT * from campaigns WHERE id not in
(SELECT e.id_campaign, d.name, d.frequency, d.country, d.referral, d.bid, d.status, COUNT(e.id) AS countcap  
FROM campaigns d
LEFT JOIN served e
ON d.id = e.id_campaign 
WHERE 
    d.status = 'Active'
GROUP BY e.id_campaign
HAVING
    countcap < d.frequency)</code>
Nach dem Login kopieren

Das Problem liegt in der Auswahl mehrerer Felder (z. B. e.id_campaign, d.name, d.frequency usw.) innerhalb der Unterabfrage. NOT IN erwartet eine einzelne Spalte zum Vergleich.

Die Lösung: Verwendung einer abgeleiteten Tabelle

Um dies zu korrigieren, können wir eine abgeleitete Tabelle (eine Unterabfrage in der FROM-Klausel) verwenden, um die relevante Spalte zu isolieren:

<code class="language-sql">SELECT *
FROM campaigns
WHERE id NOT IN (SELECT id_campaign 
                 FROM (SELECT e.id_campaign AS id_campaign, d.frequency, e.id
                       FROM campaigns d 
                       LEFT JOIN served e ON d.id = e.id_campaign
                       WHERE d.status = 'Active'
                       GROUP BY e.id_campaign
                       HAVING COUNT(e.id) < d.frequency) as subquery);</code>
Nach dem Login kopieren

Diese überarbeitete Abfrage verwendet eine abgeleitete Tabelle mit dem Namen subquery. Diese innere Abfrage führt die ursprüngliche Logik aus, wählt jedoch nur e.id_campaign (alias id_campaign) aus, um sicherzustellen, dass die äußere NOT IN-Klausel eine einspaltige Ergebnismenge erhält, wodurch der Fehler behoben wird. Die ursprüngliche Filterlogik basierend auf frequency und countcap bleibt in der abgeleiteten Tabelle erhalten.

Das obige ist der detaillierte Inhalt vonWie behebe ich den Fehler „Operand sollte 1 Spalte enthalten' in der NOT IN-Unterabfrage von MySQL?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage