Heim >Datenbank >MySQL-Tutorial >Wie wende ich eine WHERE-Klausel auf ein bestimmtes Feld in MySQL-Unterabfragen und Aggregatfunktionen an?

Wie wende ich eine WHERE-Klausel auf ein bestimmtes Feld in MySQL-Unterabfragen und Aggregatfunktionen an?

DDD
DDDOriginal
2024-11-05 15:38:02488Durchsuche

How to Apply a WHERE Clause to a Specific Field in MySQL Subqueries and Aggregate Functions?

Gibt es eine Möglichkeit, eine WHERE-Klausel für ein bestimmtes Feld in MySQL anzuzeigen?

In MySQL ist es im Allgemeinen nicht möglich, eine anzugeben WHERE-Klausel für ein bestimmtes Feld innerhalb einer Unterabfrage oder Aggregatfunktion. Es gibt jedoch bestimmte Problemumgehungen und Techniken, die dabei helfen können, ähnliche Ergebnisse zu erzielen.

Einschränkungen von WHERE-Klauseln in Unterabfragen und Aggregatfunktionen

Standardmäßig können WHERE-Klauseln nicht angewendet werden auf nicht aggregierte Spalten innerhalb einer Unterabfrage oder Aggregatfunktion. Dies liegt daran, dass MySQL diese Spalten für jede Gruppe als undefiniert behandelt, was zu widersprüchlichen Ergebnissen führt. Beispiel:

<code class="sql">SELECT
  cursos.cursoID AS idcurso,
  cursos.estadoCurso,
  cursosUsuarios.userHabilitado AS 'ok',
  GROUP_CONCAT(cursosUsuarios.userID SEPARATOR ',') AS 'usuarios'
FROM cursos
LEFT JOIN cursosUsuarios
  ON cursos.cursoID = cursosUsuarios.cursoID
 LEFT JOIN usuarios
  ON cursosUsuarios.userID = usuarios.userID
WHERE
  cursos.estadoCurso = 'abierto'
GROUP BY
  cursos.cursoID;</code>

Die obige Abfrage, die Kurse und Benutzerregistrierungsinformationen abruft, darf keine WHERE-Klausel für einen bestimmten Benutzer enthalten:

<code class="sql">WHERE usuarios.userID = 70</code>

Problemumgehungen und alternative Ansätze

Um das gewünschte Ergebnis zu erzielen, berücksichtigen Sie die folgenden Ansätze:

  • Unterabfrage mit IN-Operator: Ersetzen Sie die nicht aggregierte WHERE-Klausel in der Unterabfrage mit einem IN-Operator die spezifische Benutzer-ID aus einer sekundären Tabelle auswählen.
  • CTE (Common Table Expression): Verwenden Sie einen CTE, um die Daten vor der Anwendung der Aggregatfunktion vorzufiltern. Dies ermöglicht die Einbindung einer WHERE-Klausel für bestimmte Felder.
  • Dynamische WHERE-Klauselkonstruktion: Verwenden Sie Verkettung, um die WHERE-Klausel basierend auf Benutzereingaben oder anderen Parametern dynamisch zu erstellen.

Beispiel für die Verwendung von CTE (Common Table Expression):

Die folgende Abfrage verwendet einen CTE, um Benutzerregistrierungsdaten vor der Anwendung der Aggregatfunktion vorzufiltern:

<code class="sql">WITH FilteredEnrollments AS (
  SELECT
    userID,
    cursoID,
    userHabilitado
  FROM cursosUsuarios
  WHERE
    userID = 70
)
SELECT
  cursos.cursoID AS idcurso,
  cursos.estadoCurso,
  FilteredEnrollments.userHabilitado AS 'ok',
  GROUP_CONCAT(FilteredEnrollments.userID SEPARATOR ',') AS 'usuarios'
FROM cursos
LEFT JOIN FilteredEnrollments
  ON cursos.cursoID = FilteredEnrollments.cursoID
WHERE
  cursos.estadoCurso = 'abierto'
GROUP BY
  cursos.cursoID;</code>

In diesem Beispiel wird die Tabelle „cursosUsuarios“ mithilfe eines CTE gefiltert, um nur Datensätze für den angegebenen Benutzer einzuschließen, was die korrekte Anzeige des Felds „userHabilitado“ ermöglicht.

Das obige ist der detaillierte Inhalt vonWie wende ich eine WHERE-Klausel auf ein bestimmtes Feld in MySQL-Unterabfragen und Aggregatfunktionen an?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

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