Gruppieren von Daten mit NULL-Werten in SQL
Das Gruppieren von Daten mithilfe der GROUP BY-Funktion ist eine leistungsstarke Technik zum Zusammenfassen und Abrufen von Daten. Manchmal ist es jedoch wünschenswert, Daten zu gruppieren und dabei NULL-Werte zu ignorieren. Dies kann durch geschickte Manipulation der GROUP BY-Klausel erreicht werden.
In der angegebenen Abfrage wird GROUP BY verwendet, um Zeilen nach dem Vorfahrenfeld zu gruppieren. Wenn ancestor jedoch für mehrere Zeilen NULL ist, werden sie gruppiert, was dazu führt, dass nur eine Zeile zurückgegeben wird. Um dieses Problem zu lösen, können wir einen Trick mit der IFNULL-Funktion verwenden.
Wir können die Abfrage wie folgt ändern:
SELECT `table1`.*, IFNULL(ancestor,UUID()) as unq_ancestor GROUP_CONCAT(id SEPARATOR ',') AS `children_ids` FROM `table1` WHERE (enabled = 1) GROUP BY unq_ancestor
In dieser überarbeiteten Abfrage verwenden wir IFNULL, um ein eindeutiges Ergebnis zuzuweisen Bezeichner (UUID) auf NULL-Werte im Vorfahrenfeld. Dadurch wird eine eindeutige Spalte namens unq_ancestor erstellt, die dann zur Gruppierung verwendet wird. Dadurch werden alle Zeilen, einschließlich derjenigen mit NULL-Vorfahrenwerten, separat gruppiert, sodass Sie alle gewünschten Daten abrufen können.
Das obige ist der detaillierte Inhalt vonWie kann ich SQL-Daten gruppieren, während NULL-Werte in der „GROUP BY'-Klausel verarbeitet werden?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!