10 月 23 - 25 日,QCon 上海站即将召开,现在大会已开始正式报名,可以享受 8 折优惠 了解详情
写点什么

SQL Server 中的新数据类型:HierarchyId

  • 2007-12-02
  • 本文字数:766 字

    阅读完需:约 3 分钟

对于关系型数据库来说,表现树状的层次结构始终是一个问题。微软在 Sql Server 2005 中首次尝试了解决这个问题,那就是被称之为通用数据表表达式( Common Table Expressions ,CTE)的实现方式。

尽管 CTE 在现有的数据库架构中运行良好,微软找到了一种将此类层次结构作为头等概念来使用的方式。因此为了实现这种效果,他们在 SQL Server 2008 中提出了一种“HierarchId”数据类型。

在传统的层次结构中,一条记录仅仅储存了一个指向它父记录的引用,这使得一条记录能够获得它在层次结构中的相对位置,而不是绝对位置。改变某条记录的父数据行引用是一个原子更新操作,它不会影响到该记录的任何子记录。

一个 HierarchyId 类型的字段储存了记录在层次结构中的准确位置。 Denny Cherry 提供了一个例子,其中展示了 0x、0x58 以及 0x5AC0 三个值,它们的字符串表现形式分别为“/”,“/1/”和“/1/1/”。这就引发了有关一致性和性能方面的问题,尤其是父记录被改变的时候。 Ravi S.Maniam 建议在改变父记录操作不频繁的情况下使用这种设计方式。

与 HierarchyId 类型同时出现的还有一系列函数。GetAncestor 和GetDescendant 方法可以用来遍历树。ToString 和Parse 方法用于HierarchyId 类型二进制与字符串表现形式之前的转换。有些古怪的是,随之而来的还有用于支持BinaryReader 与BinaryWriter 的一些方法。

再来回头看看GetDescendant,这是一个有些古怪的方法。它实际上不返回那些子记录,而是返回那些潜在的子节点的位置。向树中插入一个新的记录时,我们必需调用GetDescendant 方法来获得指定父记录的最后一个子节点的位置,然后才能获得紧跟着该位置之后的空隙。

迄今为止还没有使用T-SQL 来获得树状结构的合适示例。事实上,与它有关的所有东西都更像是一些命令,而不是基于基于集合的操作。

查看英文原文: New SQL Server Data Type: HierarchyId

2007-12-02 20:491587
用户头像

发布了 157 篇内容, 共 60.3 次阅读, 收获喜欢 6 次。

关注

评论

发布
暂无评论
发现更多内容

架构师训练营大作业一

kawayi

大作业2

大作业

solike

记一次缓存服务器迁移史,心塞!

冰河

高并发 高性能 分布式缓存 数据同步 服务器迁移

【薪火计划】10 - 目标计划管理

码字与律动

管理 28天写作

架构师训练营第 1 期 - 大作业 (二)

wgl

架构师训练营第 1 期

二层环路故障处理

架构训练营第十二周作业

一期一会

大数据 hdfs hive

28 天带你玩转 Kubernetes-- 第三天(K8s 安装)

Java全栈封神

Kubernetes k8s 28天写作 k8s安装

软件架构总结图

dll

Java并发编程总结

topsion

Java 并发编程 多线程

架构师训练营第 1 期 - 大作业 (一)

wgl

架构师训练营第 1 期

[1/28]用户价值体系

L3C老司机

大作业(二)

wanlinwang

架构师设计大作业一

小诗

「架构师训练营第 1 期」

架构师训练营 4 期 第2周

引花眠

架构师训练营 4 期

架构师训练营大作业二

一马行千里

架构师训练营第 1 期

架构师训练营大作业(二)

月殇

SpringMVC学习!

程序员的时光

程序员 28天写作

给我结果

三只猫

28天写作

架构师训练营第 1 期 - 大作业(二)

鲁大江

架构师训练营第 1 期

大作业(一)

Pyr0man1ac

架构师训练营大作业二

kawayi

技术人小故事-团队愿景篇-第3段

Ian哥

28天写作

价值 - 什么是有价值的事?(3)

石云升

读书笔记 28天写作 价值

大作业-一

行者

架构师训练营第 1 期-大作业(一)

鲁大江

架构师训练营第 1 期

大作业(二)

Pyr0man1ac

大作业1

架构师训练营大作业(一)

月殇

「架构师训练营第 1 期」

十一周作业

SQL Server中的新数据类型:HierarchyId_.NET_Jonathan Allen_InfoQ精选文章