Heim > Datenbank > MySQL-Tutorial > Hauptteil

Können MySQL-JSON-Felder für die Tabellenverknüpfung verwendet werden?

Susan Sarandon
Freigeben: 2024-10-31 23:51:28
Original
107 Leute haben es durchsucht

 Can MySQL JSON Fields Be Used for Table Joining?

Verwendung des MySQL-JSON-Felds für die Tabellenverknüpfung

Bei der Datenbankverwaltung ist es häufig erforderlich, Daten aus mehreren Tabellen zu verknüpfen, um umfassende Erkenntnisse zu erhalten. Bei der Arbeit mit MySQL kann es vorkommen, dass Sie über ein JSON-Feld verfügen, in dem eine Liste von Bezeichnern gespeichert ist. In diesem Beitrag geht es um die Frage, ob es möglich ist, Operationen auf solchen JSON-Feldern auszuführen und sie in SQL-Abfragen zu nutzen.

Das Problem

Stellen Sie sich das folgende fiktive Szenario vor: Sie haben eine „Benutzer“-Tabelle mit Spalten für Benutzer-ID, Benutzername und ein JSON-Feld namens „user_groups“, das eine Liste von Gruppen-IDs speichert. Es gibt auch eine Tabelle „user_group“ mit Spalten für Gruppen-ID und Gruppennamen. Das Ziel besteht darin, eine Abfrage zu erstellen, die Informationen über Benutzer und ihre jeweiligen Gruppen abruft. Das Ergebnis ist eine Tabelle mit der folgenden Struktur:

user_id | user_name | user_group_id | group_name
Nach dem Login kopieren

Die gewünschten Ergebnisse wären:

101     | John      | 1             | Group A
101     | John      | 3             | Group C
Nach dem Login kopieren

Die Lösung

Um die gewünschten Ergebnisse zu erzielen, können Sie die folgende Abfrage verwenden:

SELECT 
       u.user_id, 
       u.user_name, 
       g.user_group_id,
       g.group_name
   FROM user u
   LEFT JOIN user_group g on JSON_CONTAINS(u.user_groups, CAST(g.user_group_id as JSON), '$')
Nach dem Login kopieren

Mit der Funktion „JSON_CONTAINS“ wird ermittelt, ob eine Benutzergruppen-ID vorhanden ist existiert im JSON-Feld „user_groups“. Mithilfe dieser Funktion können Sie die Tabellen „user“ und „user_group“ basierend auf dem Vorhandensein von Gruppen-IDs im JSON-Feld verknüpfen. Dies ermöglicht den Abruf von Informationen über Benutzer und die ihnen zugeordneten Gruppen.

Das obige ist der detaillierte Inhalt vonKönnen MySQL-JSON-Felder für die Tabellenverknüpfung verwendet werden?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
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
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage
Über uns Haftungsausschluss Sitemap
Chinesische PHP-Website:Online-PHP-Schulung für das Gemeinwohl,Helfen Sie PHP-Lernenden, sich schnell weiterzuentwickeln!