Maison > base de données > tutoriel mysql > le corps du texte

Comment implémenter une procédure stockée récursive dans MySQL pour calculer la hiérarchie des quantités ?

Barbara Streisand
Libérer: 2024-10-31 19:23:02
original
443 Les gens l'ont consulté

How to Implement a Recursive Stored Procedure in MySQL for Calculating Quantity Hierarchy?

Procédure stockée récursive pour calculer la hiérarchie des quantités

Dans MySQL, créer une procédure stockée récursive pour calculer des quantités pour des structures hiérarchiques imbriquées est un défi qui peut être surmonté grâce à une procédure soigneusement conçue. Considérez le tableau donné, où chaque ligne représente un article avec une quantité associée et un parent potentiel.

Procédure stockée récursive

Pour parcourir de manière récursive cette structure arborescente et calculer la quantité totale, la procédure stockée suivante peut être implémentée :

<code class="mysql">DELIMITER $$

CREATE PROCEDURE calctotal(
   IN number INT,
   OUT total INT
)

BEGIN

   DECLARE parent_ID INT DEFAULT NULL ;
   DECLARE tmptotal INT DEFAULT 0;
   DECLARE tmptotal2 INT DEFAULT 0;

   SELECT parentid   FROM test   WHERE id = number INTO parent_ID;   
   SELECT quantity   FROM test   WHERE id = number INTO tmptotal;     

   IF parent_ID IS NULL
    THEN
    SET total = tmptotal;
   ELSE     
    CALL calctotal(parent_ID, tmptotal2);
    SET total = tmptotal2 * tmptotal;   
   END IF;

END$$

DELIMITER ;</code>
Copier après la connexion

Exécution de la procédure

Pour activer la récursivité, il est crucial d'ajuster les paramètres MySQL :

<code class="mysql">SET @@GLOBAL.max_sp_recursion_depth = 255;
SET @@session.max_sp_recursion_depth = 255;</code>
Copier après la connexion

Une fois ces paramètres configurés, la procédure stockée peut être invoquée comme ceci :

<code class="mysql">CALL calctotal(6, @total);
SELECT @total;</code>
Copier après la connexion

Exemple de calcul récursif

Pour les exemples de données donnés, où l'élément 6 est un enfant de l'élément 5, qui est un enfant de l'élément 3, et ainsi de suite, la procédure stockée calculera récursivement la quantité totale comme suit :

4 * 2 * 10 * 3 = 240
Copier après la connexion

Par conséquent, le résultat de l'appel de l'élément la procédure avec le numéro = 6 sera 240.

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!

source:php.cn
Déclaration de ce site Web
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
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal
À propos de nous Clause de non-responsabilité Sitemap
Site Web PHP chinois:Formation PHP en ligne sur le bien-être public,Aidez les apprenants PHP à grandir rapidement!