


Comment implémenter une procédure stockée récursive dans MySQL pour calculer la hiérarchie des quantités ?
Oct 31, 2024 pm 07:23 PMProcé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>
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>
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>
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
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!

Article chaud

Outils chauds Tags

Article chaud

Tags d'article chaud

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Sujets chauds

Réduisez l'utilisation de la mémoire MySQL dans Docker

Comment modifier une table dans MySQL en utilisant l'instruction ALTER TABLE?

Comment résoudre le problème de MySQL ne peut pas ouvrir la bibliothèque partagée

Exécutez MySQL dans Linux (avec / sans conteneur Podman avec phpmyadmin)

Exécuter plusieurs versions MySQL sur macOS: un guide étape par étape

Comment sécuriser MySQL contre les vulnérabilités communes (injection SQL, attaques par force brute)?

Quels sont les outils de GUI MySQL populaires (par exemple, MySQL Workbench, PhpMyAdmin)?
