SQL GROUP BY
und ORDER BY
Konflikte bei der Benennung von Klauseln: Eine Lösung
Die ursprüngliche Abfrage stößt auf Probleme beim Gruppieren von Daten nach Hardwaremodell, Ergebnistyp und Groß-/Kleinschreibung aufgrund von Namenskonflikten zwischen der berechneten Ausdrucksspalte CASE
und der Quellspalte (attempt.result
). Dies führt zu mehreren Zeilen für identische Typ- und Fallkombinationen.
Die Lösung besteht darin, die direkte Verwendung des Quellspaltennamens innerhalb der GROUP BY
-Klausel zu vermeiden. Hier sind zwei effektive Ansätze:
Methode 1: Gruppieren Sie direkt nach dem CASE-Ausdruck:
Anstatt nach attempt.result
zu gruppieren, gruppieren Sie nach dem CASE
-Ausdruck selbst:
GROUP BY model.name, attempt.type, CASE WHEN attempt.result = 0 THEN 0 ELSE 1 END
Dadurch werden die Daten direkt basierend auf dem berechneten Ergebnis der CASE
-Anweisung gruppiert, wodurch Mehrdeutigkeiten beseitigt werden.
Methode 2: Spaltenaliase verwenden:
Weisen Sie der Ausgabespalte des CASE
-Ausdrucks einen Alias zu:
SELECT ..., CASE WHEN attempt.result = 0 THEN 0 ELSE 1 END AS result1 GROUP BY model.name, attempt.type, result1
Der Alias result1
unterscheidet die berechnete Spalte deutlich von der Quellspalte und löst so den Konflikt. Beachten Sie, dass ORDER BY
in diesem Fall den Alias-Spaltennamen (result1
) priorisiert.
Best Practice: Positionsreferenzen
Um Namenskonflikte vollständig zu vermeiden, verwenden Sie Positionsverweise innerhalb der GROUP BY
- und ORDER BY
-Klauseln. Dieser Ansatz ist weniger fehleranfällig und verbessert die Lesbarkeit der Abfrage, insbesondere bei komplexen Abfragen. Das folgende Beispiel demonstriert diese Technik innerhalb einer vereinfachten und umgeschriebenen Abfrage:
SELECT m.name, a.type, CASE WHEN a.result = 0 THEN 0 ELSE 1 END AS result, CURRENT_DATE - 1 AS day, count(*) AS ct FROM attempt a JOIN prod_hw_id p USING (hard_id) JOIN model m USING (model_id) WHERE ts >= '2013-11-06 00:00:00' AND ts < CURRENT_DATE --Corrected the incomplete WHERE clause GROUP BY 1, 2, 3 -- Positional references for model.name, a.type, result ORDER BY 1, 2, 3 -- Positional references for model.name, a.type, result
Diese überarbeitete Abfrage ist prägnanter und vermeidet mögliche Namenskonflikte. Denken Sie daran, Ihre WHERE
-Klausel immer auf Vollständigkeit zu überprüfen. Das Original war unvollständig und wurde oben korrigiert.
Das obige ist der detaillierte Inhalt vonWie löst man Namenskonflikte in SQL-Klauseln GROUP BY und ORDER BY?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

In dem Artikel werden mithilfe der Änderungstabelle von MySQL Tabellen, einschließlich Hinzufügen/Löschen von Spalten, Umbenennung von Tabellen/Spalten und Ändern der Spaltendatentypen, erläutert.

In Artikel werden die Konfiguration der SSL/TLS -Verschlüsselung für MySQL, einschließlich der Erzeugung und Überprüfung von Zertifikaten, erläutert. Das Hauptproblem ist die Verwendung der Sicherheitsauswirkungen von selbstsignierten Zertifikaten. [Charakterzahl: 159]

In Artikel werden Strategien zum Umgang mit großen Datensätzen in MySQL erörtert, einschließlich Partitionierung, Sharding, Indexierung und Abfrageoptimierung.

In Artikel werden beliebte MySQL -GUI -Tools wie MySQL Workbench und PhpMyAdmin beschrieben, die ihre Funktionen und ihre Eignung für Anfänger und fortgeschrittene Benutzer vergleichen. [159 Charaktere]

In dem Artikel werden in MySQL die Ablagerung von Tabellen mithilfe der Drop -Tabellenerklärung erörtert, wobei Vorsichtsmaßnahmen und Risiken betont werden. Es wird hervorgehoben, dass die Aktion ohne Backups, die Detaillierung von Wiederherstellungsmethoden und potenzielle Produktionsumfeldgefahren irreversibel ist.

In dem Artikel werden in verschiedenen Datenbanken wie PostgreSQL, MySQL und MongoDB Indizes für JSON -Spalten in verschiedenen Datenbanken erstellt, um die Abfrageleistung zu verbessern. Es erläutert die Syntax und die Vorteile der Indizierung spezifischer JSON -Pfade und listet unterstützte Datenbanksysteme auf.

In Artikeln werden ausländische Schlüssel zur Darstellung von Beziehungen in Datenbanken erörtert, die sich auf Best Practices, Datenintegrität und gemeinsame Fallstricke konzentrieren.

Artikel erläutert die Sicherung von MySQL gegen SQL-Injektions- und Brute-Force-Angriffe unter Verwendung vorbereiteter Aussagen, Eingabevalidierung und starken Kennwortrichtlinien (159 Zeichen).


Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

Heiße Werkzeuge

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

SAP NetWeaver Server-Adapter für Eclipse
Integrieren Sie Eclipse mit dem SAP NetWeaver-Anwendungsserver.

MinGW – Minimalistisches GNU für Windows
Dieses Projekt wird derzeit auf osdn.net/projects/mingw migriert. Sie können uns dort weiterhin folgen. MinGW: Eine native Windows-Portierung der GNU Compiler Collection (GCC), frei verteilbare Importbibliotheken und Header-Dateien zum Erstellen nativer Windows-Anwendungen, einschließlich Erweiterungen der MSVC-Laufzeit zur Unterstützung der C99-Funktionalität. Die gesamte MinGW-Software kann auf 64-Bit-Windows-Plattformen ausgeführt werden.

Dreamweaver CS6
Visuelle Webentwicklungstools

WebStorm-Mac-Version
Nützliche JavaScript-Entwicklungstools