SQL Server 2008 层级类型 hierarchyid 使用说明

作者:vkvi 来源:千一网络(原创) 日期:2012-2-23

在 hierarchyid 实现之前,大家使用 BigClass、SmallClass 或 ParentId 一类的方法实现层级,其缺陷就是要么层级数被限定,要么就是无法多层级索引。

SQL Server 2008 中有一个类型叫 hierarchyid,用来实现层级目录功能的,可以非常方便地查找祖先、父级、兄弟、儿子、后代。

方法

hierarchyid 的方法是区分大小写的。

静态方法

静态方法前面用冒号。

  • hierarchyid::GetRoot() 获取根节点值。

实例方法

实例方法前面用点号,可以对 hierarchyid 字段、变量使用。

  • phid.GetDescendant(child1, child2) 获取 phid 的下级 hierarchyid 值。
  • hid.IsDescendantOf(parent) 如果结果为 1,则说明 parent 是 hid 的祖先。
  • hid.GetLevel() 获取 hid 对应的值所处的层次,值形如 1、2、3……
  • hid.GetAncestor(n) 获取 hid 向上 n 个节点的 hierarchyid 值。
  • hid.GetReparentedValue(oldRoot, newRoot) 获取换 hid 的上级后的 hierarchyid 值。

示例、更新 hierarchyid

如下,记录插入后,使用如下代码更新该记录的 hierarchyid,这里 hierarchyid 的字段名称为 PathNode。

首先查找当前记录的父记录,如果父记录不存在,则使用 HierarchyId::GetRoot() 作为父记录的 hierarchyid。

再查找记录两个相邻的兄弟(实际上,上面的示例中由于是新插入的,所以“弟弟” @child2 并不存在),GetDescendant 就会根据父 hierarchyid 和两个兄弟的 hierarchyid 自动给出当前记录的 hierarchyid 值。

你前面那位网友看了:一起学 Microsoft AJAX Library-Type 类

▲▲▲嘿,欢迎转载传播本站原创文章,尽量保留来源噢。▲▲▲

文章评论
标题:必填
内容:
本站永远终止与捏造“罪名”不支付广告费的某度联盟合作。
vkvi
vkvi

作者简介: vkvi,致力于 .NET Web 开发、移动开发的技术推广,在 .NET、SQL Server、Windows Server 等方面有深入研究和丰富经验,10 年间共计撰写文章 4000 余篇。 主持金融、国土、农业、电商等多个行业项目执行, 推行“技术提升生产力、人心决定成功率”的管理理论。 联系他