Heim >Datenbank >MySQL-Tutorial >Wie verbinde ich Tabellen mit durch Kommas getrennten Werten in einer Spalte?
Datenbanknormalisierung ist für eine effiziente Datenverwaltung von entscheidender Bedeutung, aber manchmal erfordern Projekte möglicherweise die Verarbeitung von Altdaten in nicht normalisierter Form. In diesem Artikel wird eine Technik zum Verbinden zweier Tabellen mit durch Kommas getrennten Werten in einer bestimmten Spalte untersucht.
Szenario:
Angenommen, wir haben zwei Tabellen:
Notizentabelle:
Positionstabelle:
Unser Ziel ist es, diese Tabellen zu verbinden und die Spalte „forDepts“ mit Werten aus der Tabelle „Positions“ zu verknüpfen, wodurch eine neue Spalte mit durch Kommas getrennten Positionsnamen entsteht.
Lösung mit CONCAT_WS:
SELECT n.nid, CONCAT_WS(', ', p.name) AS DepartmentName FROM Notes n JOIN Positions p ON n.forDepts = p.id
Dieser Ansatz führt jedoch nur zum Abrufen die erste Übereinstimmung für jede Abteilungs-ID, nicht alle übereinstimmenden Abteilungen.
Lösung mit FIND_IN_SET:
SELECT a.nid, GROUP_CONCAT(b.name ORDER BY b.id) AS DepartmentName FROM Notes a INNER JOIN Positions b ON FIND_IN_SET(b.id, a.forDepts) > 0 GROUP BY a.nid
Die Funktion FIND_IN_SET prüft, ob ein Wert in einem Komma vorhanden ist -getrennte Zeichenfolge. Durch die Verwendung in der JOIN-Bedingung stellen wir sicher, dass alle passenden Positionen enthalten sind. Die Funktion GROUP_CONCAT verkettet die abgerufenen Positionsnamen, getrennt durch Kommas.
PHP-Code-Integration:
Der angegebene PHP-Code kann geändert werden, um die erweiterte Abteilungsnamenspalte durch Ersetzen abzurufen die Abfrage in der mysql_query-Anweisung mit der oben vorgeschlagenen Lösung. Dadurch kann der Code die durch Kommas getrennten Positionsnamen korrekt exportieren.
Hinweis:
Während die Normalisierung von Datenbanken ideal ist, ist manchmal der Umgang mit nicht normalisierten Daten erforderlich. Die in diesem Artikel besprochenen Techniken bieten eine Lösung zum effizienten Zusammenführen von Tabellen und zum Aggregieren durch Kommas getrennter Werte in solchen Szenarien.
Das obige ist der detaillierte Inhalt vonWie verbinde ich Tabellen mit durch Kommas getrennten Werten in einer Spalte?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!