首頁 >資料庫 >mysql教程 >MySQL遞歸查詢如何有效地擷取給定子節點的所有祖先?

MySQL遞歸查詢如何有效地擷取給定子節點的所有祖先?

DDD
DDD原創
2024-12-07 02:20:13910瀏覽

How Can MySQL Recursive Queries Efficiently Retrieve All Ancestors of a Given Child Node?

MySQL 中的分層查詢:檢索祖先關係

為了有效管理分層數據,MySQL 提供了強大的遞歸查詢,可以導航任意深度的關係。當您需要提取祖先關係時,這變得特別有用。

考慮以下關係結構,其中「a」代表父字段,「b」代表子字段:

| a  | b  |
-----------
| 1  | 2  |
| 2  | 3  |
| 3  | 4  |
| 4  | 5  |
| 3  | 6  |
| 4  | 7  |

問題:給定一個子字段值(例如5),確定其所有父字段、祖父母等

解決方案:

MySQL 提供了遞歸通用表表達式(CTE),使您能夠有效地導航分層關係:

WITH RECURSIVE Ancestors AS (
    SELECT  *
    FROM    mytable
    WHERE   b = 5
    UNION ALL
    SELECT  t1.*
    FROM    mytable t1
    JOIN    Ancestors t2 ON t1.a = t2.b
)
SELECT  a, b
FROM    Ancestors;

此查詢建立一個名為「Ancestors」的遞歸CTE,它迭代地識別每個的父級層次結構中的子字段。 CTE 首先選擇值為 5(即 5)的子欄位。然後,它使用“a”(父)和“b”(子)欄位將“mytable”連接到自身。這個遞歸過程一直持續到沒有更多的父字段可供檢索。

最終的 SELECT 語句從「Ancestors」CTE 中提取「a」(父)和「b」(子)字段,提供想要的層次關係。

執行時,此查詢會傳回以下結果:

a  | b
-----------
1  | 2
2  | 3
3  | 4
4  | 5

因此,成功擷取所提供的子欄位值的父母、祖父母和進一步的祖先。

以上是MySQL遞歸查詢如何有效地擷取給定子節點的所有祖先?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

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