MySQL實現任意級子目錄的主要方案以及區別

常見的實現方案及區別

1. 鄰接表(Adjacency List)

方案描述:
  • 每條記錄存儲一個節點的父節點ID。

  • 表結構大致:

    id INT PRIMARY KEY,
    name VARCHAR(...),
    parent_id INT  -- 指向父節點的ID,根節點為NULL或0
    
優點:
  • 結構簡單,直觀,容易維護。

  • 插入、刪除單條節點簡單。

缺點:
  • 查詢整個樹或任意節點的所有子孫節點比較復雜,需遞歸多次查詢(MySQL 8.0之前不支持遞歸CTE,查詢性能低)。

  • 需要遞歸處理。


2. 路徑枚舉(Path Enumeration)

方案描述:
  • 每條記錄保存從根節點到當前節點的完整路徑。

  • 例如路徑字段path存儲為/1/5/9/

  • 表結構大致:

    id INT PRIMARY KEY,
    name VARCHAR(...),
    path VARCHAR(...)  -- 存儲路徑字符串
    
優點:
  • 查詢所有子孫節點通過LIKE 'path%'即可,查詢簡單。

  • 不用遞歸,查詢效率較高。

缺點:
  • 修改節點路徑(如移動節點)時,需要更新所有子節點路徑,操作復雜且成本高。

  • 路徑字段存儲占用空間較大。


3. 嵌套集合模型(Nested Set Model)

方案描述:
  • 利用左右值(left, right)表示節點的范圍區間。

  • 每個節點有兩個整數值lftrgt,表示在樹中的先序遍歷位置。

  • 表結構大致:

    id INT PRIMARY KEY,
    name VARCHAR(...),
    lft INT,
    rgt INT
    
優點:
  • 查詢子孫節點非常快(單次范圍查詢)。

  • 適合大量讀,查詢頻繁的場景。

缺點:
  • 插入、刪除、移動節點時,需要調整大量節點的lftrgt值,操作復雜。

  • 維護成本高。


4. 閉包表(Closure Table)

方案描述:
  • 額外建一個關聯表,存儲節點之間的所有祖先-后代關系。

  • 關聯表結構:

    ancestor_id INT,
    descendant_id INT,
    depth INT  -- 距離,0表示自身
    
優點:
  • 查詢任意節點的所有子孫和所有祖先非常方便且性能好。

  • 插入刪除只需要維護關聯表,靈活。

缺點:
  • 需要額外的存儲空間。

  • 維護關聯表的操作相對復雜。


5. MySQL 8.0+ 的遞歸公共表表達式(CTE)

  • MySQL 8.0支持遞歸CTE,鄰接表查詢樹形數據變得更簡單。

  • 利用遞歸CTE實現遞歸查詢,無需額外結構。


總結對比

方案查詢復雜度插入/更新復雜度存儲成本適用場景
鄰接表遞歸查詢,慢簡單數據結構簡單,更新頻繁
路徑枚舉簡單LIKE查詢復雜,需更新路徑中等讀多寫少,結構變化不頻繁
嵌套集合簡單范圍查詢復雜,調整左右值讀多寫少,查詢性能要求高
閉包表簡單且靈活維護關聯表復雜需要頻繁查詢任意層級關系
遞歸CTE(MySQL8+)簡單遞歸查詢簡單適合任意層級遞歸查詢,無需額外表

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/bicheng/87714.shtml
繁體地址,請注明出處:http://hk.pswp.cn/bicheng/87714.shtml
英文地址,請注明出處:http://en.pswp.cn/bicheng/87714.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

Linux網絡socket套接字(完)(5)

文章目錄前言一、多進程版的Tcp網絡程序捕捉SIGCHLD信號讓孫子進程提供服務二、多線程版的Tcp網絡程序三、線程池版的Tcp網絡程序四、Tcp協議通訊流程通訊流程總覽三次握手的過程數據傳輸的過程四次揮手的過程總結前言 結束嘍,至少這個Tcp套接字有關內容要結束了~ ?…

Web3 Study Log 003

Web3 Study Log 003 2025-7-5 這幾天各種各樣的瑣事,處理完了,真的煩,估計能消停一段時間了… 今天終于能夠坐下來好好學習,今天學習了chainlink的使用,能夠獲取 ETH/USD 實時價格,然后寫了一個簡單的眾…

Kotlin:2.1.20 的新特性

一、概述 The Kotlin 2.1.20 release is here! Here are the main highlights: Kotlin 2.1.20發布了,主要亮點如下: K2 compiler updates: updates to the new kapt and Lombok pluginsKotlin Multiplatform: new DSL to replace Gradle’s Application …

設計模式 | 觀察者模式

觀察者模式(Observer Pattern)是行為型設計模式中的事件通知專家,它定義了對象間一種一對多的依賴關系,當一個對象狀態改變時,所有依賴它的對象都會自動收到通知并更新。這種模式實現了發布-訂閱機制,是事件…

Apache Struts2 遠程命令執行漏洞(S2-052)

一、漏洞概述 S2-052 是 Apache Struts2 框架中一個高危的遠程代碼執行漏洞(CVE-2017-9805),由安全研究人員于 2017 年發現并公開。該漏洞源于 Struts2 的 REST 插件在使用 XStream 組件處理 XML 反序列化時,未對用戶輸入的 XML 數…

RS觸發器Multisim電路仿真——硬件工程師筆記

目錄 1 RS觸發器基礎知識 1.1 工作原理 1.2 電路結構 1.3 特點 1.4 應用 1.5 設計考慮 1.6 總結 2 與非門實現基本RS觸發器 2.1 電路結構 2.2 工作原理 2.3 特點 2.4 總結 3 或非門實現基本RS觸發器 3.1 電路結構 3.2 工作原理 3.3 特點 3.4 總結 4 與非門實…

提示技術系列(12)——程序輔助語言模型

什么是提示技術? 提示技術是實現提示工程目標的具體技術手段,是提示工程中的“工具庫”。 什么又是提示工程? 提示工程是指通過設計、優化和迭代輸入到大語言模型(LLM)的提示(Prompt)&#xff…

明遠智睿H618:開啟多場景智慧生活新時代

在數字化浪潮的推動下,智能設備正深刻地改變著我們的生活方式。明遠智睿H618以其強大的功能和卓越的性能,在家庭娛樂、商業展示、教育培訓和智能家居控制等多個領域展現出巨大的應用潛力,開啟了多場景智慧生活的新時代。 家庭娛樂&#xff1…

探秘展銷編輯器:相較于傳統展銷的卓越優勢與甄選指南?

在競爭激烈的商業環境中,企業期望通過展銷活動提升品牌知名度、推廣產品和拓展市場,但傳統展銷方式存在諸多難題。一是場地限制,優質場地稀缺、租金貴、檔期緊,場地空間和布局也不一定合適;二是展示形式單一,多為靜態展…

第31篇:塊設備與字符設備管理深度解析(基于OpenEuler 24.03)

塊設備與字符設備管理深度解析(基于OpenEuler 24.03) 文章目錄 塊設備與字符設備管理深度解析(基于OpenEuler 24.03)一、設備基礎概念體系1.1 塊設備的核心特性與分類1.2 字符設備的流式數據模型1.3 設備標識系統:主設…

Django Channels WebSocket實時通信實戰:從聊天功能到消息推送

引言 在Web開發中,實時通信功能(如在線聊天、實時通知、數據推送)已成為許多應用的核心需求。傳統的HTTP協議由于其請求-響應模式的限制,無法高效實現實時通信。WebSocket作為一種全雙工通信協議,為實時Web應用提供了…

day52 神經網絡調參指南

目錄 隨機種子 內參的初始化 神經網絡調參指南 參數的分類 調參順序 初始化參數 batchsize的選擇 學習率調整 激活函數的選擇 損失函數的選擇 模型架構中的參數 正則化系數 其他補充 隨機種子 import torch import torch.nn as nn# 定義簡單的線性模型&#xf…

.NET9 實現斐波那契數列(FibonacciSequence)性能測試

在 .NET 平臺上實現 斐波那契數列 并使用 BenchmarkDotNet 進行性能測試&#xff0c;是評估不同算法實現方式性能表現的一種高效且標準化的方法。通過該方式&#xff0c;可以對比遞歸、迭代、記憶化遞歸以及結合高性能優化技術&#xff08;如 Span<T>、Memory<T> 和…

三、docker軟件安裝:gitlab,nexus,mysql8,redis,nacos,nginx

目錄 1.gitlab安裝 2.nexus安裝 (1)下載啟動 (2)設置中央倉庫遠程地址 (3)配置maven的settings.xml 3.mysql8安裝 4.redis安裝 5.nacos安裝 6.nginx安裝 1.gitlab安裝 #創建目錄 cd /usr/local/ mkdir docker cd docker/ mkdir gitlab_docker cd gitlab_docker…

【與AI+】SAP WEBGUI集成開發與SAP INTERNET服務的關系

前言&#xff1a;這是我的水水專欄第五篇文章&#xff0c;這個專欄呢&#xff0c;是放一些我向AI提問的問題&#xff0c;以及AI的回答。因為感覺真的好方便哈哈哈~ 我不是很確定我的專欄文章內容是否涉及版權&#xff0c;以及也不確定這些整合過的文字是否涉嫌抄襲&#xff0c…

淺談幾種js設計模式

JavaScript設計模式是開發中常用的一種解決方案&#xff0c;它們幫助開發者以一種更結構化、更易維護的方式編寫代碼。本文將深入介紹幾種常見的JavaScript設計模式&#xff0c;包括單例模式、工廠模式、觀察者模式和策略模式。 一、單例模式&#xff08;Singleton Pattern&am…

手寫 Vue 中虛擬 DOM 到真實 DOM 的完整過程

目錄 一、虛擬 DOM 的核心概念 二、虛擬 DOM 到真實 DOM 的流程 三、手寫虛擬 DOM 到真實 DOM 的實現 1. 定義虛擬 DOM 的結構&#xff08;VNode&#xff09; 2. 創建虛擬 DOM 轉真實 DOM 的函數 3. 掛載虛擬 DOM 到頁面 4. 更新虛擬 DOM 的過程&#xff08;Diff 算法簡化…

jmm--volatile

指令重排基礎概念 在現代處理器和編譯器為了提高程序執行效率&#xff0c;會對指令進行優化&#xff0c;其中一種優化方式就是指令重排序。在單線程環境下&#xff0c;指令重排序不會影響最終執行結果&#xff0c;因為處理器和編譯器會保證重排序后的執行結果與按照代碼順序執行…

【硬件開發】濾波電容的選擇:原理、計算與多電壓值應用實踐

濾波電容的選擇&#xff1a;原理、計算與多電壓值應用實踐 1. 引言 在現代電子系統中&#xff0c;穩定的電源供應是保證電路可靠運行的基礎。然而&#xff0c;電源線上往往不可避免地存在各種噪聲和紋波&#xff0c;這些干擾可能源自電源本身&#xff08;如整流后的脈動直流&…

【seismic unix數據生成-unif2】

Seismic Unix簡介 Seismic Unix&#xff08;SU&#xff09;是由科羅拉多礦業學院&#xff08;Colorado School of Mines&#xff09;開發的開源地震數據處理軟件包&#xff0c;專為地震勘探數據分析和研究設計。它提供了一系列命令行工具&#xff0c;支持從數據加載、處理到可…