Maison >base de données >tutoriel mysql >Comment regrouper les produits correspondants dans SQL Server à l'aide de requêtes récursives ?

Comment regrouper les produits correspondants dans SQL Server à l'aide de requêtes récursives ?

DDD
DDDoriginal
2025-01-05 13:19:41328parcourir

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

SQL Server : requête récursive pour regrouper les produits correspondants

Dans une table de base de données relationnelle nommée « correspondances », chaque enregistrement représente une correspondance entre deux produits. Le but est de créer un tableau « groupes » qui capture ces correspondances dans une structure hiérarchique. Plus précisément, la colonne "group_ID" doit stocker l'ID de produit minimum parmi ceux qui appartiennent au même groupe.

Pour ce faire, nous pouvons exploiter la puissance des requêtes récursives en SQL. Une requête récursive effectue plusieurs séries d'opérations sur les mêmes données. Voici une solution qui utilise une expression de table commune (CTE) pour suivre les opérations récursives :

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

Le cas de base de la récursivité est lorsqu'un produit n'a aucune correspondance, auquel cas il forme son propre groupe. Ceci est capturé dans la première partie du CTE.

    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

La partie récursive du CTE trouve tous les produits correspondants pour chaque groupe. Il ajoute de manière itérative ces produits correspondants au groupe.

    SELECT
        C.Group_ID,
        M.matching_Product_Id
    FROM CTE C
        JOIN matches M
            ON C.Product_ID = M.Product_ID

Enfin, nous pouvons récupérer les résultats par ordre hiérarchique en triant le CTE par la colonne "Group_ID".

SELECT * FROM CTE ORDER BY Group_ID

Ceci la requête récursive produit efficacement le regroupement souhaité de produits dans la table « groupes ». La relation hiérarchique est capturée par la colonne « group_ID », garantissant que chaque ligne reflète un groupe de produits distinct.

En tirant parti des capacités récursives de SQL Server, nous pouvons extraire efficacement des modèles hiérarchiques complexes et regrouper les données associées dans des formats complexes. structures de base de données.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn