成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

嵌套集合模型(Nested set model)介紹

Half / 2004人閱讀

摘要:原文鏈接歡迎作客我們的學(xué)習(xí)群本文翻譯自維基百科嵌套集合模型是一種在關(guān)系型數(shù)據(jù)庫中表示嵌套集合的特殊技術(shù)。誘因該技術(shù)的出現(xiàn)解決了標(biāo)準(zhǔn)關(guān)系代數(shù)和關(guān)系演算以及基于它們的操作不能直接在層次結(jié)構(gòu)上表示所有期望操作的問題。這通常被稱為物料清單問題。

原文鏈接:http://www.pilishen.com/posts...; 歡迎作客我們的php&Laravel學(xué)習(xí)群:109256050
本文翻譯自維基百科Nested set model

?nested set model(嵌套集合模型)是一種在關(guān)系型數(shù)據(jù)庫中表示nested sets(嵌套集合)?的特殊技術(shù)。[nested sets]通常指的是關(guān)系樹或者層級關(guān)系。這個術(shù)語是由?Joe Celko清晰的提出來的,還有人使用不同的術(shù)語來描述這一技術(shù)。

誘因

該技術(shù)的出現(xiàn)解決了標(biāo)準(zhǔn)關(guān)系代數(shù)和關(guān)系演算以及基于它們的SQL操作不能直接在層次結(jié)構(gòu)上表示所有期望操作的問題。層級可以用parent-child relation (父子關(guān)系)術(shù)語來表示 - Celko稱之為?[adjacency list model],但是如果可以有任意的深度,這種模型不能用來展示類似的操作比如比較兩個元素的層級或者確定一個元素是否位于另一個元素的子層級,當(dāng)一個層級結(jié)構(gòu)是固定的或者有固定的深度,這種操作必須通過每一層的?relational join#Joins_and_join-like_operators)?(關(guān)系連接)來實現(xiàn)。但是這將很低效。這通常被稱為物料清單問題。

通過切換到圖形數(shù)據(jù)庫,可以很容易地表達層次結(jié)構(gòu)。另外在一些關(guān)系型數(shù)據(jù)庫系統(tǒng)中存在并提供了這種關(guān)系模型的解決方案:

支持專門的層級結(jié)構(gòu)數(shù)據(jù)類型,比如SQL的hierarchical query?facility(層級查詢工具)。

使用層級操作擴展關(guān)系型語言,比如?nested relational algebra。

使用transitive closure擴展關(guān)系型語言,比如SQL的CONNECT語句;這可以在parent-child relation 使用但是執(zhí)行起來比較低效。

層級結(jié)構(gòu)查詢可以在支持循環(huán)且包裹關(guān)系的操作的語言中實現(xiàn)。比如?PL/SQL,?T-SQL?or a?general-purpose programming language

當(dāng)這些解決方案沒被提供或不容易實現(xiàn),就必須使用另一種方法

技術(shù)

嵌套集模型是根據(jù)樹遍歷來對節(jié)點進行編號,遍歷會訪問每個節(jié)點兩次,按訪問順序分配數(shù)字,并在兩次訪問中都分配。這將為每個節(jié)點留下兩個數(shù)字,它們作為節(jié)點兩個屬性存儲。這使得查詢變得高效:通過比較這些數(shù)字來獲得層級結(jié)構(gòu)關(guān)系。但是更新數(shù)據(jù)將需要給節(jié)點重新分配數(shù)字,因此變得低效。盡管很復(fù)雜但是可以通過不使用整數(shù)而是用有理數(shù)來改進更新速度。

例子

在衣服庫存目錄中,衣服可能會更加層級機構(gòu)來分類:

[](//en.wikipedia.org/wiki/File:NestedSetModel.svg)

[](//en.wikipedia.org/wiki/File:Clothing-hierarchy-traversal-2.svg)

處于層級結(jié)構(gòu)頂端的Clothing分類包含所有的子類,因此它的左值和右值分別賦值為1和22,后面的值即這里的22是展現(xiàn)的所有節(jié)點總數(shù)的兩倍。下一層級包含Men"s和Women"s兩子類,各自包含必須被計算在內(nèi)的層級。每一層的節(jié)點都根據(jù)它們包含的子層級來給左值和右值賦值。如上表所示。

表現(xiàn)

使用nested sets 將比使用一個遍歷adjacency list的儲存過程更快,對于天生缺乏遞歸的查詢結(jié)構(gòu)也是更快的選擇。比如MySQL.但是遞歸SQL查詢語句也能提供類似“迅速查詢后代”的語句并且在其他深度搜索查詢是更快,所以也是對于提供這一功能的數(shù)據(jù)庫的更快選擇。例如?PostgreSQL,[[5]](//en.wikipedia.org/wiki/Nested_set_model#cite_note-5)
?Oracle,[[6]](//en.wikipedia.org/wiki/Nested_set_model#cite_note-6)
?and?Microsoft SQL Server.[[7]](//en.wikipedia.org/wiki/Nested_set_model#cite_note-7)

缺點

The use case for a dynamic endless database tree hierarchy is rare. The Nested Set model is appropriate where the tree element and one or two attributes are the only data, but is a poor choice when more complex relational data exists for the elements in the tree. Given an arbitrary starting depth for a category of "Vehicles" and a child of "Cars" with a child of "Mercedes", a foreign key table relationship must be established unless the tree table is naively non-normalized. Attributes of a newly created tree item may not share all attributes with a parent, child or even a sibling. If a foreign key table is established for a table of "Plants" attributes, no integrity is given to the child attribute data of "Trees" and its child "Oak". Therefore, in each case of an item inserted into the tree, a foreign key table of the item"s attributes must be created for all but the most trivial of use cases.
If the tree isn"t expected to change often, a properly normalized hierarchy of attribute tables can be created in the initial design of a system, leading to simpler, more portable SQL statements; specifically ones that don"t require an arbitrary number of runtime, programmatically created or deleted tables for changes to the tree. For more complex systems, hierarchy can be developed through relational models rather than an implicit numeric tree structure. Depth of an item is simply another attribute rather than the basis for an entire DB architecture. As stated in?SQL Antipatterns:[[8]](//en.wikipedia.org/wiki/Nested_set_model#cite_note-8)

Nested Sets is a clever solution – maybe too clever. It also fails to support referential integrity. It’s best used when you need to query a tree more frequently than you need to modify the tree.[[9]](//en.wikipedia.org/wiki/Nested_set_model#cite_note-9)

The model doesn"t allow for multiple parent categories. For example, an "Oak" could be a child of "Tree-Type", but also "Wood-Type". An additional tagging or taxonomy has to be established to accommodate this, again leading to a design more complex than a straightforward fixed model.
Nested sets are very slow for inserts because it requires updating left and right domain values for all records in the table after the insert. This can cause a lot of database stress as many rows are rewritten and indexes rebuilt. However, if it is possible to store a forest of small trees in table instead of a single big tree, the overhead may be significantly reduced, since only one small tree must be updated.
The?nested interval model?does not suffer from this problem, but is more complex to implement, and is not as well known. It still suffers from the relational foreign-key table problem. The nested interval model stores the position of the nodes as rational numbers expressed as quotients (n/d).?[[1]](//www.sigmod.org/publications/sigmod-record/0506/p47-article-tropashko.pdf)

變體

使用上面描述的nested set modal 在一些特定的樹遍歷操作上有性能限制。比如根據(jù)父節(jié)點查找直接子節(jié)點需要刪選子樹到一個指定的層級如下所示:

SELECT Child.Node, Child.Left, Child.Right
FROM Tree as Parent, Tree as Child
WHERE
    Child.Left BETWEEN Parent.Left AND Parent.Right
    AND NOT EXISTS (    -- No Middle Node
        SELECT *
        FROM Tree as Mid
        WHERE Mid.Left BETWEEN Parent.Left AND Parent.Right
                 AND Child.Left BETWEEN Mid.Left AND Mid.Right
            AND Mid.Node NOT IN (Parent.Node AND Child.Node)
    )
    AND Parent.Left = 1  -- Given Parent Node Left Index

或者:

SELECT DISTINCT Child.Node, Child.Left, Child.Right
FROM Tree as Child, Tree as Parent 
WHERE Parent.Left < Child.Left AND Parent.Right > Child.Right  -- associate Child Nodes with ancestors
GROUP BY Child.Node, Child.Left, Child.Right
HAVING max(Parent.Left) = 1  -- Subset for those with the given Parent Node as the nearest ancestor

當(dāng)查詢不止一層深度的子節(jié)點的時候,查詢將更加的復(fù)雜,為了突破限制和簡化遍歷樹,在模型上增加一個額外的字段來維護樹內(nèi)節(jié)點的深度:

在這個模型中,找到指定父節(jié)點的緊跟直接子節(jié)點可以使用下面的SQL語句實現(xiàn):

SELECT Child.Node, Child.Left, Child.Right
FROM Tree as Child, Tree as Parent
WHERE
    Child.Depth = Parent.Depth + 1
    AND Child.Left > Parent.Left
    AND Child.Right < Parent.Right
    AND Parent.Left = 1  -- Given Parent Node Left Index

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/28169.html

相關(guān)文章

  • Adjacent List ModelNested Set Model 兩種無線分類模型的對比

    摘要:相反,我們添加了一個第三自連接,以及一個子查詢以確定這個深度將作為子樹的新起點這個函數(shù)可以被運用到任何節(jié)點上,包括根節(jié)點。我們可以在之前的語句上添加一條語句來輕松實現(xiàn)如果想顯示父節(jié)點,將改為。 原文鏈接:http://www.pilishen.com/posts... 我們都曾在數(shù)據(jù)庫中處理過層級數(shù)據(jù)-這種數(shù)據(jù)中的每項都有一個父項和(0或多個)子項,根項除外。比如:論壇和郵件列表中的...

    sshe 評論0 收藏0
  • 使用 Baum 嵌套集合模型來實現(xiàn) Laravel 模型的無限極分類

    摘要:本文經(jīng)授權(quán)轉(zhuǎn)自社區(qū)使用嵌套集合模型來實現(xiàn)模型的無限極分類說明大家通常都是使用遞歸實現(xiàn)無限極分類,都知道遞歸效率很低,下面推薦一個的擴展包,快速讓你的數(shù)據(jù)模型支持無限極樹狀層級結(jié)構(gòu),并且兼顧效率。 本文經(jīng)授權(quán)轉(zhuǎn)自 PHPHub 社區(qū) 使用 Baum 嵌套集合模型來實現(xiàn) Laravel 模型的無限極分類 說明 大家通常都是使用遞歸實現(xiàn)無限極分類,都知道遞歸效率很低,下面推薦一個 Larav...

    superPershing 評論0 收藏0
  • Nodejs+Express學(xué)習(xí)二(Mongoose基礎(chǔ)了解)

    摘要:學(xué)習(xí)注定少不了與數(shù)據(jù)庫打交道,而和可以說是絕配,這篇主要是簡單介紹這個模塊。通過創(chuàng)建查詢是數(shù)據(jù)庫中運用最多也是最麻煩的地方,這里對解讀的并不完善,僅僅是自己的一點領(lǐng)悟而已。 學(xué)習(xí)Node注定少不了與數(shù)據(jù)庫打交道,而MongoDB和Node可以說是絕配,這篇主要是簡單介紹Mongoose這個模塊。由于本人也是邊學(xué)邊寫的這篇文章,絕對會有新手的味道,請大神看到這里就表往下看了。 名詞介紹稍...

    617035918 評論0 收藏0
  • Nodejs+Express學(xué)習(xí)二(Mongoose基礎(chǔ)了解)

    摘要:學(xué)習(xí)注定少不了與數(shù)據(jù)庫打交道,而和可以說是絕配,這篇主要是簡單介紹這個模塊。通過創(chuàng)建查詢是數(shù)據(jù)庫中運用最多也是最麻煩的地方,這里對解讀的并不完善,僅僅是自己的一點領(lǐng)悟而已。 學(xué)習(xí)Node注定少不了與數(shù)據(jù)庫打交道,而MongoDB和Node可以說是絕配,這篇主要是簡單介紹Mongoose這個模塊。由于本人也是邊學(xué)邊寫的這篇文章,絕對會有新手的味道,請大神看到這里就表往下看了。 名詞介紹稍...

    LiangJ 評論0 收藏0
  • laravel-nestedset:多級無限分類正確姿勢

    摘要:通過自定義的查詢加載和大多數(shù)情況下,你需要按層級排序祖先集合可以被預(yù)加載視圖模板中面包屑將祖先的全部取出后轉(zhuǎn)換為數(shù)組,在用拼接為字符串輸出。 原文鏈接:http://www.pilishen.com/posts...; 歡迎作客我們的php&Laravel學(xué)習(xí)群:109256050 laravel-nestedset是一個關(guān)系型數(shù)據(jù)庫遍歷樹的larvel4-5的插件包 目錄: Nes...

    pf_miles 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<