首頁 >資料庫 >mysql教程 >如何在單一 MySQL 查詢中檢索遞歸類別?

如何在單一 MySQL 查詢中檢索遞歸類別?

Barbara Streisand
Barbara Streisand原創
2024-11-10 19:41:02745瀏覽

How to Retrieve Recursive Categories in a Single MySQL Query?

使用單一 MySQL 查詢進行遞迴類別檢索

在 Web 應用程式中,將內容組織到分層類別中很常見。複雜的類別結構(例如樹)需要專門的檢索處理。本文探討了使用單一 MySQL 查詢來取得遞迴類別的最有效方法。

使用引用在 PHP 中建立類別樹可以最佳化該過程。查詢檢索類別及其父 ID,這些 ID 儲存在關聯數組 ($nodeList) 中。此陣列的結構是為了建立分層引用,其中每個節點的父節點出現在其「parent」鍵中。

樹的構造發生在以下程式碼中:

foreach ($nodeList as $nodeId => &$node) {
    if (!$node['parent'] || !array_key_exists($node['parent'], $nodeList)) {
        $tree[] = &$node;
    } else {
        $nodeList[$node['parent']]['children'][] = &$node;
    }
}

此循環迭代節點,如果一個節點沒有父節點或父節點不存在於數組中,則該節點將被添加到$tree 數組中。否則,該節點將作為子節點新增至其父節點的「children」數組。

結果是儲存在 $tree 陣列中的分層樹結構,每個節點都包含子節點參考。這種單一查詢方法比使用遞歸 MySQL 查詢快得多,即使對於大型類別樹也是如此。

以上是如何在單一 MySQL 查詢中檢索遞歸類別?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn