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

作者:vkvi 来源:ITPOW(原创) 日期: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 值。

相关文章