[TREE]一理想的在关系数据库中存储树型结构数据的方法.doc

[TREE]一理想的在关系数据库中存储树型结构数据的方法.doc

  1. 1、本文档共9页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
[TREE]一理想的在关系数据库中存储树型结构数据的方法

一种理想的在关系数据库中存储树型结构数据的方法 2008-03-07 15:49 ??? 在各种基于关系数据库的应用系统开发中,我们往往需要存储树型结构的数据,目前有很多流行的方法,如邻接列表模型(The Adjacency List Model),在此基础上也有很多人针对不同的需求做了相应的改进,但总是在某些方面存在的各种各样的缺陷。 ??? 那么理想中的树型结构应具备哪些特点呢?数据存储冗余小、直观性强;方便返回整个树型结构数据;可以很轻松的返回某一子树(方便分层加载);快整获以某节 点的祖谱路径;插入、删除、移动节点效率高等等。带着这些需求我查找了很多资料,发现了一种理想的树型结构数据存储及操作算法,改进的前序遍历树模型 (The Nested Set Model)。 一、数据 ??? 在本文中,举一个在线食品店树形图的例子。这个食品店通过类别、颜色和品种来组织食品。树形图如下: 二、邻接列表模型(The Adjacency List Model) 在这种模型下,上述数据在关系数据库的表结构数据通常如下图所示: 由于该模型比较简单,在此不再详细介绍其算法,下面列出它的一些不足: ??? 在大多数编程语言中,他运行很慢,效率很差。这主要是“递归”造成的。我们每次查询节点都要访问数据库。每次数据库查询都要花费一些时间,这让函数处理庞 大的树时会十分慢。造成这个函数不是太快的第二个原因可能是你使用的语言。不像Lisp这类语言,大多数语言不是针对递归函数设计的。对于每个节点,函数都要调用他自己,产生新的 实例。这样,对于一个4层的树,你可能同时要运行4个函数副本。对于每个函数都要占用一块内存并且需要一定的时间初始化,这样处理大树时递归就很慢了。 三、改进的前序遍历树模型(The Nested Set Model) 原理: ??? 我们先把树按照水平方式摆开。从根节点开始(“Food”),然后他的左边写上1。然后按照树的顺序(从上到下)给“Fruit”的左边写上2。这样,你 沿着树的边界走啊走(这就是“遍历”),然后同时在每个节点的左边和右边写上数字。最后,我们回到了根节点“Food”在右边写上18。下面是标上了数字 的树,同时把遍历的顺序用箭头标出来了。 ??? 我们称这些数字为左值和右值(如,“Food”的左值是1,右值是18)。正如你所见,这些数字按时了每个节点之间的关系。因为“Red”有3和6两个 值,所以,它是有拥有1-18值的“Food”节点的后续。同样的,我们可以推断所有左值大于2并且右值小于11的节点,都是有2-11的“Fruit” 节点的后续。这样,树的结构就通过左值和右值储存下来了。这种数遍整棵树算节点的方法叫做“改进前序遍历树”算法。 表结构设计: 常用的操作: 下面列出一些常用操作的SQL语句 返回完整的树(Retrieving a Full Tree) SELECT node.name ??FROM nested_category node, nested_category parent WHERE node.lft BETWEEN parent.lft AND parent.rgt ???AND parent.name = electronics ORDER BY node.lft 返回某结点的子树(Find the Immediate Subordinates of a Node) SELECT V.* ??FROM (SELECT node.name, (COUNT(parent.name) - (AVG(sub_tree.depth) + 1)) depth ??????????FROM nested_category node, ??????????????? nested_category parent, ??????????????? nested_category sub_parent, ??????????????? (SELECT V.* ??????????????????FROM (SELECT node.name, (COUNT(parent.name) - 1) depth ??????????????????????????FROM nested_category node, nested_category parent ?????????????????????????WHERE node.lft BETWEEN parent.lft AND parent.rgt ???????????????????????????AND node.name = portable electronics ?????????????????????????GROUP

文档评论(0)

nbc152 + 关注
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档