在 MySQL 中建立遞歸預存程序來決定給定項目的計算數量需要了解表結構和遞歸邏輯。
問題背景
給定一個包含「id」、「parent_id」和「數量」列的表,目標是透過以下方式計算商品的總數量遞歸遍歷其父子關係。例如,第 6 項的計算數量為 240,因為其父項為 5(數量 4)、3(數量 2)和 2(數量 10)。
解決方案:遞歸預存程序
<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>
過程呼叫
呼叫儲存程序並取得第6 題的計算數量:
<code class="mysql">SET @@GLOBAL.max_sp_recursion_depth = 255; SET @@session.max_sp_recursion_depth = 255; CALL calctotal(6, @total); SELECT @total;</code>
過程分解
以上是如何在 MySQL 中使用遞歸預存程序來計算運算量?的詳細內容。更多資訊請關注PHP中文網其他相關文章!