Heim >Datenbank >MySQL-Tutorial >Wie verbinde ich Tabellen mit durch Kommas getrennten Werten in einer Spalte?

Wie verbinde ich Tabellen mit durch Kommas getrennten Werten in einer Spalte?

Linda Hamilton
Linda HamiltonOriginal
2024-12-08 12:00:21423Durchsuche

How to Join Tables with Comma-Separated Values in a Column?

Tabellen mit durch Kommas getrennten Werten verbinden

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:

    • nid: Hinweis ID
    • forDepts: Durch Kommas getrennte Abteilungs-IDs
  • Positionstabelle:

    • id: Positions-ID
    • Name: Position Name

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!

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