


Kann ich das mit reinem MySQL lösen? (Verknüpfen bei ; Getrennte Werte in einer Spalte)
Problem:
Sie haben Daten in zwei Tabellen gespeichert, wobei eine Spalte in der ersten Tabelle mehrere auflistet Werte durch Semikolons getrennt. Sie müssen einen Inner Join basierend auf diesen getrennten Werten durchführen, haben aber keine Verknüpfungstabelle und können keine externen Programmiersprachen verwenden.
Diskussion:
Die Herausforderung besteht darin, die durch Semikolons getrennte Liste in separate Zeilen umzuwandeln, um eine Verknüpfung mit der zweiten Tabelle zu ermöglichen. Dies kann mithilfe einer Technik namens „Ableiten“ oder „Normalisieren“ der Daten erreicht werden.
Lösung:
1. Erstellen Sie eine Ganzzahlreihentabelle:
Um die Daten zu normalisieren, benötigen Sie zunächst eine Tabelle, die einen Zahlenbereich enthält. In diesem Fall könnten Sie eine Integerseries-Tabelle mit IDs von 1 bis zur maximalen Anzahl von Elementen erstellen, die Sie in der durch Semikolons getrennten Liste erwarten.
2. Verwenden Sie JOIN und Unterabfragen:
Sobald Sie die Integerseries-Tabelle haben, führen Sie die folgende Abfrage aus:
<code class="sql">SELECT user_resource.user, resource.data FROM user_resource JOIN integerseries AS isequence ON isequence.id <p><strong>Erklärung:</strong></p> <ul> <li>Diese Abfrage verknüpft die Tabelle „user_resource“ mit der Tabelle „Integerseries“, um eine Reihe von Zeilen für jeden Benutzer und jedes Element in der entsprechenden Ressourcenspalte zu generieren.</li> <li>Die Funktion COUNT_IN_SET zählt die Anzahl der Elemente in der Ressourcenspalte und Die Funktion VALUE_IN_SET extrahiert ein bestimmtes Element basierend auf der isequence.id.</li> <li>Der abschließende Join mit der Ressourcentabelle gleicht das extrahierte Element mit der ID ab, um die entsprechenden Daten abzurufen.</li> </ul> <p><strong>Zusätzliche Funktionen (optional):</strong></p> <p>Die Abfrage verwendet zwei benutzerdefinierte Funktionen, COUNT_IN_SET und VALUE_IN_SET, die wie folgt definiert werden können:</p> <pre class="brush:php;toolbar:false"><code class="sql">-- Function to count the number of delimited items in a string DELIMITER $$ DROP FUNCTION IF EXISTS `COUNT_IN_SET`$$ CREATE FUNCTION `COUNT_IN_SET`(haystack VARCHAR(1024), delim CHAR(1) ) RETURNS INTEGER BEGIN RETURN CHAR_LENGTH(haystack) - CHAR_LENGTH( REPLACE(haystack, delim, '')) + 1; END$$ DELIMITER ; -- Function to get the value at a specific index in a delimited string DELIMITER $$ DROP FUNCTION IF EXISTS `VALUE_IN_SET`$$ CREATE FUNCTION `VALUE_IN_SET`(haystack VARCHAR(1024), delim CHAR(1), which INTEGER ) RETURNS VARCHAR(255) CHARSET utf8 COLLATE utf8_unicode_ci BEGIN RETURN SUBSTRING_INDEX(SUBSTRING_INDEX(haystack, delim, which), delim, -1); END$$ DELIMITER ;</code>
Diese Funktionen bieten eine generische Möglichkeit um durch Trennzeichen getrennte Zeichenfolgen in SQL-Abfragen zu bearbeiten.
Beispieltabellen und -daten:
<code class="sql">-- Integerseries table CREATE TABLE `integerseries` ( `id` int(11) NOT NULL AUTO_INCREMENT, PRIMARY KEY (`id`) ); -- Resource table CREATE TABLE `resource` ( `id` int(11) NOT NULL, `data` varchar(250) DEFAULT NULL, PRIMARY KEY (`id`) ); -- Data for resource table INSERT INTO `resource` (`id`, `data`) VALUES (1, 'abcde'), (2, 'qwerty'), (3, 'azerty'); -- User_resource table CREATE TABLE `user_resource` ( `user` varchar(50) NOT NULL, `resources` varchar(250) DEFAULT NULL, PRIMARY KEY (`user`) ); -- Data for user_resource table INSERT INTO `user_resource` (`user`, `resources`) VALUES ('sampleuser', '1;2;3'), ('stacky', '2'), ('testuser', '1;3');</code>
Ausgabe:
Ausführen der Eine Abfrage der Beispieldaten erzeugt die folgende Ausgabe:
+----------+-------+ | user | data | +----------+-------+ | sampleuser | abcde | | sampleuser | qwerty | | sampleuser | azerty | | stacky | qwerty | | testuser | abcde | | testuser | azerty | +----------+-------+
Das obige ist der detaillierte Inhalt vonKann ich Tabellen mit durch Semikolons getrennten Werten in MySQL ohne externe Tools verknüpfen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

In diesem Artikel wird die Optimierung von MySQL -Speicherverbrauch in Docker untersucht. Es werden Überwachungstechniken (Docker -Statistiken, Leistungsschema, externe Tools) und Konfigurationsstrategien erörtert. Dazu gehören Docker -Speichergrenzen, Tausch und CGroups neben

Dieser Artikel befasst sich mit MySQLs Fehler "Die freigegebene Bibliotheksfehler". Das Problem ergibt sich aus der Unfähigkeit von MySQL, die erforderlichen gemeinsam genutzten Bibliotheken (.SO/.dll -Dateien) zu finden. Lösungen beinhalten die Überprüfung der Bibliotheksinstallation über das Paket des Systems m

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.

Dieser Artikel vergleicht die Installation von MySQL unter Linux direkt mit Podman -Containern mit/ohne phpmyadmin. Es beschreibt Installationsschritte für jede Methode und betont die Vorteile von Podman in Isolation, Portabilität und Reproduzierbarkeit, aber auch

Dieser Artikel bietet einen umfassenden Überblick über SQLite, eine in sich geschlossene, serverlose relationale Datenbank. Es beschreibt die Vorteile von SQLite (Einfachheit, Portabilität, Benutzerfreundlichkeit) und Nachteile (Parallelitätsbeschränkungen, Skalierbarkeitsprobleme). C

In diesem Handbuch wird die Installation und Verwaltung mehrerer MySQL -Versionen auf macOS mithilfe von Homebrew nachgewiesen. Es betont die Verwendung von Homebrew, um Installationen zu isolieren und Konflikte zu vermeiden. Der Artikel Details Installation, Starten/Stoppen von Diensten und Best PRA

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 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]


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

Sicherer Prüfungsbrowser
Safe Exam Browser ist eine sichere Browserumgebung für die sichere Teilnahme an Online-Prüfungen. Diese Software verwandelt jeden Computer in einen sicheren Arbeitsplatz. Es kontrolliert den Zugriff auf alle Dienstprogramme und verhindert, dass Schüler nicht autorisierte Ressourcen nutzen.

ZendStudio 13.5.1 Mac
Leistungsstarke integrierte PHP-Entwicklungsumgebung

SublimeText3 Englische Version
Empfohlen: Win-Version, unterstützt Code-Eingabeaufforderungen!

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools
