Heim Datenbank MySQL-Tutorial Wie gruppiere ich übereinstimmende Produkte in SQL Server mithilfe rekursiver Abfragen?

Wie gruppiere ich übereinstimmende Produkte in SQL Server mithilfe rekursiver Abfragen?

Jan 05, 2025 pm 01:19 PM

How to Group Matched Products in SQL Server Using Recursive Queries?

SQL Server: Rekursive Abfrage zum Gruppieren übereinstimmender Produkte

In einer relationalen Datenbanktabelle mit dem Namen „matches“ stellt jeder Datensatz eine Übereinstimmung zwischen zwei dar Produkte. Das Ziel besteht darin, eine „Gruppen“-Tabelle zu erstellen, die diese Übereinstimmungen in einer hierarchischen Struktur erfasst. Insbesondere sollte die Spalte „group_ID“ die minimale Produkt-ID derjenigen speichern, die derselben Gruppe angehören.

Um dies zu erreichen, können wir die Leistungsfähigkeit rekursiver Abfragen in SQL nutzen. Eine rekursive Abfrage führt mehrere Operationsrunden für dieselben Daten durch. Hier ist eine Lösung, die einen gemeinsamen Tabellenausdruck (CTE) verwendet, um rekursive Vorgänge zu verfolgen:

WITH CTE
AS
(
    SELECT DISTINCT
        M1.Product_ID AS Group_ID,
        M1.Product_ID
    FROM matches M1
        LEFT JOIN matches M2
            ON M1.Product_Id = M2.matching_Product_Id
    WHERE M2.matching_Product_Id IS NULL
    UNION ALL
    SELECT
        C.Group_ID,
        M.matching_Product_Id
    FROM CTE C
        JOIN matches M
            ON C.Product_ID = M.Product_ID
)
SELECT * FROM CTE ORDER BY Group_ID
Nach dem Login kopieren

Der Basisfall der Rekursion liegt vor, wenn ein Produkt keine Übereinstimmungen aufweist. In diesem Fall bildet es eine eigene Gruppe. Dies wird im ersten Teil des CTE erfasst.

    SELECT DISTINCT
        M1.Product_ID AS Group_ID,
        M1.Product_ID
    FROM matches M1
        LEFT JOIN matches M2
            ON M1.Product_Id = M2.matching_Product_Id
    WHERE M2.matching_Product_Id IS NULL
Nach dem Login kopieren

Der rekursive Teil des CTE findet alle passenden Produkte für jede Gruppe. Diese passenden Produkte werden der Gruppe iterativ hinzugefügt.

    SELECT
        C.Group_ID,
        M.matching_Product_Id
    FROM CTE C
        JOIN matches M
            ON C.Product_ID = M.Product_ID
Nach dem Login kopieren

Schließlich können wir die Ergebnisse in hierarchischer Reihenfolge abrufen, indem wir den CTE nach der Spalte „Group_ID“ sortieren.

SELECT * FROM CTE ORDER BY Group_ID
Nach dem Login kopieren

Dies Eine rekursive Abfrage erzeugt effektiv die gewünschte Gruppierung von Produkten in der Tabelle „Gruppen“. Die hierarchische Beziehung wird durch die Spalte „group_ID“ erfasst und stellt sicher, dass jede Zeile eine bestimmte Produktgruppe widerspiegelt.

Durch die Nutzung der rekursiven Funktionen von SQL Server können wir komplexe hierarchische Muster effizient extrahieren und verwandte Daten in komplexen Gruppen gruppieren Datenbankstrukturen.

Das obige ist der detaillierte Inhalt vonWie gruppiere ich übereinstimmende Produkte in SQL Server mithilfe rekursiver Abfragen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

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

Heiße Artikel -Tags

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Reduzieren Sie die Verwendung des MySQL -Speichers im Docker Reduzieren Sie die Verwendung des MySQL -Speichers im Docker Mar 04, 2025 pm 03:52 PM

Reduzieren Sie die Verwendung des MySQL -Speichers im Docker

Wie verändern Sie eine Tabelle in MySQL mit der Änderungstabelleanweisung? Wie verändern Sie eine Tabelle in MySQL mit der Änderungstabelleanweisung? Mar 19, 2025 pm 03:51 PM

Wie verändern Sie eine Tabelle in MySQL mit der Änderungstabelleanweisung?

So lösen Sie das Problem der MySQL können die gemeinsame Bibliothek nicht öffnen So lösen Sie das Problem der MySQL können die gemeinsame Bibliothek nicht öffnen Mar 04, 2025 pm 04:01 PM

So lösen Sie das Problem der MySQL können die gemeinsame Bibliothek nicht öffnen

Was ist SQLite? Umfassende Übersicht Was ist SQLite? Umfassende Übersicht Mar 04, 2025 pm 03:55 PM

Was ist SQLite? Umfassende Übersicht

Führen Sie MySQL in Linux aus (mit/ohne Podman -Container mit Phpmyadmin) Führen Sie MySQL in Linux aus (mit/ohne Podman -Container mit Phpmyadmin) Mar 04, 2025 pm 03:54 PM

Führen Sie MySQL in Linux aus (mit/ohne Podman -Container mit Phpmyadmin)

Ausführen mehrerer MySQL-Versionen auf macOS: Eine Schritt-für-Schritt-Anleitung Ausführen mehrerer MySQL-Versionen auf macOS: Eine Schritt-für-Schritt-Anleitung Mar 04, 2025 pm 03:49 PM

Ausführen mehrerer MySQL-Versionen auf macOS: Eine Schritt-für-Schritt-Anleitung

Wie sichere ich mich MySQL gegen gemeinsame Schwachstellen (SQL-Injektion, Brute-Force-Angriffe)? Wie sichere ich mich MySQL gegen gemeinsame Schwachstellen (SQL-Injektion, Brute-Force-Angriffe)? Mar 18, 2025 pm 12:00 PM

Wie sichere ich mich MySQL gegen gemeinsame Schwachstellen (SQL-Injektion, Brute-Force-Angriffe)?

Wie konfiguriere ich die SSL/TLS -Verschlüsselung für MySQL -Verbindungen? Wie konfiguriere ich die SSL/TLS -Verschlüsselung für MySQL -Verbindungen? Mar 18, 2025 pm 12:01 PM

Wie konfiguriere ich die SSL/TLS -Verschlüsselung für MySQL -Verbindungen?

See all articles